第一步:添加依赖
首先,你需要将 MyBatis-Plus 的依赖添加到你的项目的 pom.xml
文件中。
<dependencies>
<!-- 其他依赖... -->
<!-- MyBatis-Plus -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.1</version>
</dependency>
<!-- MyBatis-Plus 代码生成器依赖 -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.5.1</version>
<scope>test</scope>
</dependency>
<!-- FreeMarker 模板引擎依赖,用于生成代码 -->
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>2.3.31</version>
</dependency>
<!-- 数据库驱动依赖,以 MySQL 为例 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.25</version>
</dependency>
</dependencies>
第二步:配置 application.properties
或 application.yml
在你的 application.properties
文件中添加 MyBatis-Plus 和数据库相关配置:
# 数据源配置
spring.datasource.url=jdbc:mysql://localhost:3306/your_database?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
spring.datasource.username=your_username
spring.datasource.password=your_password
# MyBatis-Plus 配置
mybatis-plus.mapper-locations=classpath:/mapper/**/*.xml
mybatis-plus.type-aliases-package=com.u7i7.aigc.entity
mybatis-plus.global-config.db-config.id-type=auto
第三步:编写代码生成器
创建一个测试类,例如 CodeGenerator.java
,用于生成代码:
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.config.OutputFile;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import java.util.Collections;
public class CodeGenerator {
public static void main(String[] args) {
FastAutoGenerator.create("jdbc:mysql://localhost:3306/your_database", "your_username", "your_password")
.globalConfig(builder -> {
builder.author("author") // 设置作者
.fileOverride() // 覆盖已生成文件
.outputDir(System.getProperty("user.dir") + "/src/main/java") // 指定输出目录
.dateType(DateType.TIME_PACK); // 定义生成的实体类中日期类型
})
.packageConfig(builder -> {
builder.parent("com.u7i7.aigc") // 设置父包名
.pathInfo(Collections.singletonMap(OutputFile.mapperXml, System.getProperty("user.dir") + "/src/main/resources/mapper")); // 设置mapperXml生成路径
})
.strategyConfig(builder -> {
builder.addInclude("your_table_name") // 设置需要生成的表名
.addTablePrefix("t_", "c_"); // 设置过滤表前缀
})
.execute();
}
}
import com.baomidou.mybatisplus.generator.FastAutoGenerator;
import com.baomidou.mybatisplus.generator.config.OutputFile;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import java.util.Collections;
public class CodeGenerator {
public static void main(String[] args) {
FastAutoGenerator.create("jdbc:mysql://localhost:3306/your_database", "your_username", "your_password")
.globalConfig(builder -> {
builder.author("author") // 设置作者名
.fileOverride() // 覆盖已存在的文件
.outputDir(System.getProperty("user.dir") + "/src/main/java") // 指定输出目录
.dateType(DateType.TIME_PACK) // 设置时间类型为 Java 8 新的时间类型
.enableSwagger() // 开启 swagger 模式
.disableOpenDir(); // 禁止打开输出目录
})
.packageConfig(builder -> {
builder.parent("com.u7i7.aigc") // 设置父包名
.entity("entity")
.service("service")
.serviceImpl("service.impl")
.controller("controller")
.pathInfo(Collections.singletonMap(OutputFile.mapperXml, System.getProperty("user.dir") + "/src/main/resources/mapper")); // 设置mapperXml生成路径
})
.strategyConfig(builder -> {
builder.addInclude("your_table_name") // 设置需要生成的表名
.addTablePrefix("t_", "c_") // 设置过滤表前缀
.entityBuilder().enableLombok() // 启用 lombok 模型
.controllerBuilder().enableRestStyle() // 开启生成@RestController 控制器
.serviceBuilder().formatServiceFileName("%sService") // 自定义 service 接口文件名称
.formatServiceImplFileName("%sServiceImpl"); // 自定义 service 实现类文件名称
})
.templateEngine(new FreemarkerTemplateEngine()) // 使用 Freemarker 引擎模板,默认的是 Velocity 引擎模板
.execute();
}
}
1. 确保 Mapper 接口上有 @Mapper
注解
import org.apache.ibatis.annotations.Mapper;
@Mapper
public interface CategoryMapper extends BaseMapper<Category> {
// ...
}