mybatis-plus代码生成器详细教程与代码
mybatis-plus代码生成器是一个工具类,它可以根据数据库表的结构,自动创建对应的实体类、mapper接口、mapper.xml文件、service接口和controller类。这样可以节省开发者的时间和精力,避免重复的编码工作。mybatis-plus代码生成器的使用步骤如下:
文章目录
一:导入依赖
在pom文件中导入下面两个依赖,并刷新
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.4.1</version>
</dependency>
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity-engine-core</artifactId>
<version>2.0</version>
</dependency>
二、创建代码生成器对象
- 先将以下代码复制到生成器对象中
package com.yangzhuo.yx;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
import com.baomidou.mybatisplus.generator.config.GlobalConfig;
import com.baomidou.mybatisplus.generator.config.PackageConfig;
import com.baomidou.mybatisplus.generator.config.StrategyConfig;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
public class CodeGet {
public static void main(String[] args) {
// 1、创建代码生成器
AutoGenerator mpg = new AutoGenerator();
// 2、全局配置
// 全局配置
GlobalConfig gc = new GlobalConfig();
gc.setOutputDir("D:\\javaProject\\yangzhuo-yx-parent\\service\\service-sys"+"/src/main/java");
gc.setServiceName("%sService"); //去掉Service接口的首字母I
gc.setAuthor("yangzhuo");
gc.setOpen(false);
mpg.setGlobalConfig(gc);
// 3、数据源配置
DataSourceConfig dsc = new DataSourceConfig();
dsc.setUrl("jdbc:mysql://localhost:3306/shequ-sys?serverTimezone=GMT%2B8&useSSL=false");
dsc.setDriverName("com.mysql.cj.jdbc.Driver");
dsc.setUsername("root");
dsc.setPassword("1234");
dsc.setDbType(DbType.MYSQL);
mpg.setDataSource(dsc);
// 4、包配置
PackageConfig pc = new PackageConfig();
pc.setParent("com.yangzhuo.yx");
pc.setModuleName("sys"); //模块名
pc.setController("controller");
pc.setService("service");
pc.setMapper("mapper");
mpg.setPackageInfo(pc);
// 5、策略配置
StrategyConfig strategy = new StrategyConfig();
strategy.setInclude("region","ware","region_ware");
strategy.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略
strategy.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略
strategy.setEntityLombokModel(true); // lombok 模型 @Accessors(chain = true) setter链式操作
strategy.setRestControllerStyle(true); //restful api风格控制器
strategy.setControllerMappingHyphenStyle(true); //url中驼峰转连字符
mpg.setStrategy(strategy);
// 6、执行
mpg.execute();
}
}
三、修改代码中的配置
1 、代码第22行
将这里面的地址改成自己当前模块所在地址
这是模块前缀地址
根据模块层级地址继续拼接地址,完整路径为:“D:\javaProject\yangzhuo-yx-parent\service\service-sys”+“/src/main/java”
2、代码25行
这一行代码的意思是设置生成的代码的作者为"yangzhuo"。这个属性会在每个类的注释中显示,这一行代码可改可不改
3、代码31行
这里改成自己数据库的名称:比如我的数据库是这样
4、代码34、35行
改成自己数据库的账号,密码
5、代码40~44行
改成自己需要的目录级:上面的设置生成代码后是以下的目录级,参考修改
6、代码50行
这里面写上自己数据库实体类名称,注意,要完全一致,以下是我的数据库实体类名
四、运行该方法
控制台显示生成完成即为成功!
五、总结
可大大提升开发效率,希望能帮到大家