首先用idea快速创建一个springboot项目
然后配置pom依赖
// 数据库驱动
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
// velocity模板,代码生成功能需要
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity</artifactId>
<version>1.7</version>
</dependency>
// 生成代码主要的包
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.2.0</version>
</dependency>
// 包含mybatis的包(也可以用mybatis的包而不是mybatisplus的包,两者有区别)
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.2.0</version>
</dependency>
然后在启动类上加上注解 @MapperScan("com.hyy.test.mapper")
注:这个的用途是扫描mapper接口,为其生成实体类。和在mapper接口上加@mapper注解一样的效果,不过@Mapper需要在所有mapper接口上加。
然后在配置文件里加上xml文件路径
mybatis-plus.mapper-locations=classpath*:com/hyy/test/mapper/xml/*.xml
注:此处和前面mybatis-plus的选择有关,如果选的是mybatis,则填
mybatis.mapper-locations=classpath*:com/hyy/test/mapper/xml/*.xml
如果你的xml文件和我一样是放在java目录下的话,那还需要额外的一步
在pom.xml中添加
<resources>
<resource>
<!-- xml放在java目录下-->
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
</resource>
</resources>
最后再加上mybatis-plus生成代码的类
public class CodeGenerator {
public static void main(String[] args) {
// 1、创建代码生成器
AutoGenerator mpg = new AutoGenerator();
// 2、全局配置
GlobalConfig gc = new GlobalConfig();
String projectPath = System.getProperty("user.dir");
gc.setOutputDir(projectPath + "/src/main/java");
gc.setAuthor("hyy");
// 生成后是否打开资源管理器
gc.setOpen(false);
// 重新生成时文件是否覆盖
gc.setFileOverride(false);
// 去掉Service接口的首字母I
gc.setServiceName("%sService");
// 定义生成的实体类中日期类型
gc.setDateType(DateType.ONLY_DATE);
gc.setIdType(IdType.NONE);
// 开启Swagger2模式
gc.setSwagger2(false);
mpg.setGlobalConfig(gc);
// 3、数据源配置
DataSourceConfig dsc = new DataSourceConfig();
dsc.setUrl("");
dsc.setDriverName("com.mysql.cj.jdbc.Driver");
dsc.setUsername("");
dsc.setPassword("");
dsc.setDbType(DbType.MYSQL);
mpg.setDataSource(dsc);
// 4、包配置
PackageConfig pc = new PackageConfig();
pc.setParent("com.hyy.test");
// pc.setController("controller");
pc.setService("service");
pc.setMapper("mapper");
pc.setEntity("Entity");
mpg.setPackageInfo(pc);
// 5、策略配置
StrategyConfig strategy = new StrategyConfig();
strategy.setInclude("aaa"); //单独一张表
// 数据库表映射到实体的命名策略
strategy.setNaming(NamingStrategy.underline_to_camel);
// 数据库表字段映射到实体的命名策略
strategy.setColumnNaming(NamingStrategy.underline_to_camel);
// lombok 模型 @Accessors(chain = true) setter链式操作
strategy.setEntityLombokModel(true);
// restful api风格控制器
strategy.setRestControllerStyle(true);
// url中驼峰转连字符
strategy.setControllerMappingHyphenStyle(true);
mpg.setStrategy(strategy);
// 6、执行
mpg.execute();
}
}