Mybatis-plus以及生成器的使用

  • Post author:
  • Post category:其他




Mybatis-plus简介

mybatis-plus是在mybatis的基础上,只做衍生扩展不影响正常使用。

详情可参考mybatis官网:

https://baomidou.com/



Mybatis-plus使用

1.添加依赖,本处使用了mysql

        <dependency>
			<groupId>com.baomidou</groupId>
			<artifactId>mybatis-plus-boot-starter</artifactId>
			<version>3.3.1.tmp</version>
		</dependency>
		<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
		</dependency>
		<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>druid-spring-boot-starter</artifactId>
			<version>1.1.21</version>
		</dependency>
		<!--减少开发量,本人不建议使用-->
		<dependency>
   		  <groupId>org.projectlombok</groupId>
          <artifactId>lombok</artifactId>
          <version>1.18.10</version>
       </dependency>

2.新建一张表,练习测试,本图仅供参考

在这里插入图片描述

3.在spring的配置文件之中添加配置参数,本人习惯yml格式

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    username: root
    password: 123456
    url: jdbc:mysql://localhost:3306/testMyBatisPlus?useUnicode=true&characterEncoding=utf8

4.根据对应的表,创建对应的实体类,仅供参考

@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class User implements Serializable {
    private static final long serialVersionUID=1L;
    @TableId(value = "user_id", type = IdType.ASSIGN_ID)
    private String userId;
    private String username;
    private String password;
    private String salt;
    private String nickname;
    private String email;
    private String phone;
    private Integer sex;
    private Integer age;
    private String img;
    private Integer status;
    private Date createTime;
    private Date updateTime;
    private Date lastLoginTime;
}

5.编写mapper接口,使其继承BaseMapper接口来实现封装好的增删改查用法,感兴趣的可以自行点击进去看有什么用法

在这里插入图片佛挡杀佛挡杀描述
6.先得在启动类里扫描 Mapper 类,即添加 @MapperScan 注解,需要输入对应的包名

在这里插入图片描述

7.可以编写一个测试类,测试mybatis自带的用法,也可以自定义语句使用。

@Test
	public void testSelect() {
		System.out.println("开始查询user表");
		List<User> users = userMapper.selectList(null);
		if (users.size() != 0 && users != null) {
			for (User user : users) {
				System.out.println("查询出来的user的记录为:" + user);
			}
		} else {
			System.out.println("开始查询user表为空");
		}
	}



Mybatis生成器使用

1.添加生成器依赖

        <dependency>
			<groupId>com.baomidou</groupId>
			<artifactId>mybatis-plus-generator</artifactId>
			<version>3.3.1.tmp</version>
		</dependency>
		<!-- 添加 模板引擎 依赖 -->
		<dependency>
			<groupId>org.apache.velocity</groupId>
			<artifactId>velocity-engine-core</artifactId>
			<version>2.2</version>
		</dependency>

2.创建生成器对象

AutoGenerator mpg = new AutoGenerator();

3.设置全局变量

// Step2:全局配置
GlobalConfig gc = new GlobalConfig();
// 填写代码生成的目录(需要修改)
String projectPath = "F:\\eclipse_workForMybatis\\test-mybatis-plus";
// 拼接出代码最终输出的目录
gc.setOutputDir(projectPath + "/src/main/java");
// 配置开发者信息(可选)(需要修改)
gc.setAuthor("gongs");
// 配置是否打开目录,false 为不打开(可选)
gc.setOpen(false);
// 实体属性 Swagger2 注解,添加 Swagger 依赖,开启 Swagger2 模式(可选)
//gc.setSwagger2(true);
// 重新生成文件时是否覆盖,false 表示不覆盖(可选)
gc.setFileOverride(false);
// 配置主键生成策略,此处为 ASSIGN_ID(可选)
gc.setIdType(IdType.ASSIGN_ID);
// 配置日期类型,此处为 ONLY_DATE(可选)
gc.setDateType(DateType.ONLY_DATE);
// 默认生成的 service 会有 I 前缀
gc.setServiceName("%sService");
mpg.setGlobalConfig(gc);

4.数据库信息配置

// Step3:数据源配置(需要修改)
DataSourceConfig dsc = new DataSourceConfig();
// 配置数据库 url 地址
dsc.setUrl("jdbc:mysql://localhost:3306/db_blog?useUnicode=true&characterEncoding=utf8");
// dsc.setSchemaName("testMyBatisPlus"); // 可以直接在 url 中指定数据库名
// 配置数据库驱动
dsc.setDriverName("com.mysql.cj.jdbc.Driver");
// 配置数据库连接用户名
dsc.setUsername("root");
// 配置数据库连接密码
dsc.setPassword("123456");
mpg.setDataSource(dsc);

5.生成包位置配置

// Step:4:包配置

PackageConfig pc = new PackageConfig();

// 配置父包名(需要修改)

pc.setParent(“com.answer.test”);

// 配置模块名(需要修改)

pc.setModuleName(“mybatisplus”);

// 配置 entity 包名

pc.setEntity(“entity”);

// 配置 mapper 包名

pc.setMapper(“mapper”);

// 配置 service 包名

pc.setService(“service”);

// 配置 controller 包名

pc.setController(“controller”);

mpg.setPackageInfo(pc);

6.策略配置

/ Step5:策略配置(数据库表配置)
StrategyConfig strategy = new StrategyConfig();
// 指定表名(可以同时操作多个表,使用 , 隔开)(需要修改)
strategy.setInclude("user");
// 配置数据表与实体类名之间映射的策略
strategy.setNaming(NamingStrategy.underline_to_camel);
// 配置数据表的字段与实体类的属性名之间映射的策略
strategy.setColumnNaming(NamingStrategy.underline_to_camel);
// 配置 lombok 模式
strategy.setEntityLombokModel(true);
// 配置 rest 风格的控制器(@RestController)
strategy.setRestControllerStyle(true);
// 配置驼峰转连字符
strategy.setControllerMappingHyphenStyle(true);
// 配置表前缀,生成实体时去除表前缀
// 此处的表名为 test_mybatis_plus_user,模块名为 test_mybatis_plus,去除前缀后剩下为 user。
strategy.setTablePrefix(pc.getModuleName() + "_");
mpg.setStrategy(strategy);

7.执行生成器

// Step6:执行代码生成操作
 mpg.execute();


总代码,亲测可用

@Test
	public void testGenerate() {
		System.out.println("生成器开始");
		AutoGenerator mpg = new AutoGenerator();

		// Step2:全局配置
		GlobalConfig gc = new GlobalConfig();
        // 填写代码生成的目录(需要修改)
		String projectPath = "F:\\eclipse_workForMybatis\\test-mybatis-plus";
       // 拼接出代码最终输出的目录
		gc.setOutputDir(projectPath + "/src/main/java");
       // 配置开发者信息(可选)(需要修改)
		gc.setAuthor("gongs");
       // 配置是否打开目录,false 为不打开(可选)
		gc.setOpen(false);
       // 实体属性 Swagger2 注解,添加 Swagger 依赖,开启 Swagger2 模式(可选)
      //gc.setSwagger2(true);
      // 重新生成文件时是否覆盖,false 表示不覆盖(可选)
		gc.setFileOverride(false);
      // 配置主键生成策略,此处为 ASSIGN_ID(可选)
		gc.setIdType(IdType.ASSIGN_ID);
      // 配置日期类型,此处为 ONLY_DATE(可选)
		gc.setDateType(DateType.ONLY_DATE);
     // 默认生成的 service 会有 I 前缀
		gc.setServiceName("%sService");
		mpg.setGlobalConfig(gc);

		// Step3:数据源配置(需要修改)
		DataSourceConfig dsc = new DataSourceConfig();
       // 配置数据库 url 地址
		dsc.setUrl("jdbc:mysql://localhost:3306/db_blog?useUnicode=true&characterEncoding=utf8");
       // dsc.setSchemaName("testMyBatisPlus"); // 可以直接在 url 中指定数据库名
      // 配置数据库驱动
		dsc.setDriverName("com.mysql.cj.jdbc.Driver");
      // 配置数据库连接用户名
		dsc.setUsername("root");
      // 配置数据库连接密码
		dsc.setPassword("123456");
		mpg.setDataSource(dsc);


		// Step:4:包配置
		PackageConfig pc = new PackageConfig();
        // 配置父包名(需要修改)
		pc.setParent("com.answer.test");
        // 配置模块名(需要修改)
		pc.setModuleName("mybatisplus");
        // 配置 entity 包名
		pc.setEntity("entity");
       // 配置 mapper 包名
		pc.setMapper("mapper");
       // 配置 service 包名
		pc.setService("service");
      // 配置 controller 包名
		pc.setController("controller");
		mpg.setPackageInfo(pc);


		// Step5:策略配置(数据库表配置)
		StrategyConfig strategy = new StrategyConfig();
       // 指定表名(可以同时操作多个表,使用 , 隔开)(需要修改)
		strategy.setInclude("user");
      // 配置数据表与实体类名之间映射的策略
		strategy.setNaming(NamingStrategy.underline_to_camel);
      // 配置数据表的字段与实体类的属性名之间映射的策略
		strategy.setColumnNaming(NamingStrategy.underline_to_camel);
      // 配置 lombok 模式
		strategy.setEntityLombokModel(true);
      // 配置 rest 风格的控制器(@RestController)
		strategy.setRestControllerStyle(true);
      // 配置驼峰转连字符
		strategy.setControllerMappingHyphenStyle(true);
      // 配置表前缀,生成实体时去除表前缀
     // 此处的表名为 test_mybatis_plus_user,模块名为 test_mybatis_plus,去除前缀后剩下为 user。
		strategy.setTablePrefix(pc.getModuleName() + "_");
		mpg.setStrategy(strategy);


		// Step6:执行代码生成操作
		mpg.execute();

		System.out.println("生成器结束");
	}



版权声明:本文为weixin_44833594原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。