前言
SpringBoot3.0 开始最低要求 Java 17,虽然目前最新的版本为 JDK22,但是在官网上看到 JDK23 在今年9月又要发布了,感觉这 JDK 也有点太过于给力了
所以我们选择用目前的 LTS 版本 JDK21 就好了,不用追求最新的
springboot 版本
从官网的 https://start.spring.io/ 可以看到,目前的 SpringBoot 的最新正式版为 3.2.5,JAVA版本支持 17、21、22
mybatis-plus 版本
mybatis-plus 针对 springboot3.x 发布了新的依赖库,我们要选择带 spring-boot3 的版本
项目整合
项目资源下载
创建项目
JDK 选择 21,Java 选择 21
Spring Boot 选择 3.2.5,依赖选择 Spring Web
最后点击 Create 创建项目
pom.xml 文件
引入了 mybatis-plus 依赖包,还有对应生成器所需的依赖包
4.0.0
org.springframework.boot
spring-boot-starter-parent
3.2.5
org.liurb
Springboot3-CRUD
0.0.1-SNAPSHOT
Springboot3-CRUD
Springboot3-CRUD
21
3.5.6
2.3.32
8.4.0
org.springframework.boot
spring-boot-starter-web
com.baomidou
mybatis-plus-spring-boot3-starter
${mybatis-plus.version}
com.baomidou
mybatis-plus-generator
${mybatis-plus.version}
com.mysql
mysql-connector-j
${mysql-connector-java.version}
runtime
org.freemarker
freemarker
${freemarker.version}
org.projectlombok
lombok
org.springframework.boot
spring-boot-starter-test
test
org.springframework.boot
spring-boot-maven-plugin
生成代码
我们创建一张表 demo_user 进行测试
创建代码生成器
public class CodeGenerator {
// 数据库连接配置
private static final String JDBC_DRIVER = "com.mysql.cj.jdbc.Driver";
private static final String JDBC_URL = "jdbc:mysql://192.168.1.31:3307/my_db?useSSL=false";
private static final String JDBC_USER_NAME = "test_usr";
private static final String JDBC_PASSOWRD = "test_usr#Passw0rd";
// 输出目录
private static final String MAIN_JAVA_PATH = "/src/main/java";
private static final String MAIN_MAPPER_PATH = "/src/main/resources/mapper";
// 包名和模块名
private static final String PACKAGE_NAME = "org.liurb.springboot3";
private static final String MODULE_NAME = "crud";
// 表名,多个表使用英文逗号分割
private static final String TBL_NAMES = "demo_user";
// 表名的前缀,从表生成代码时会去掉前缀
private static final String TABLE_PREFIX = "";
// 生成代码入口main方法
public static void main(String[] args) {
FastAutoGenerator.create(JDBC_URL, JDBC_USER_NAME, JDBC_PASSOWRD)
.globalConfig(builder -> builder
.author("liurb") // 设置作者
.outputDir(Paths.get(System.getProperty("user.dir")) + MAIN_JAVA_PATH) // 输出路径
.commentDate("yyyy-MM-dd")
.disableOpenDir() // 禁止打开输出目录
)
.packageConfig(builder -> builder
.parent(PACKAGE_NAME) // 设置需要生成的表名
.moduleName(MODULE_NAME) // 设置过滤表前缀
.pathInfo(Collections.singletonMap(OutputFile.xml, Paths.get(System.getProperty("user.dir")) + MAIN_MAPPER_PATH)) // 设置mapperXml生成路径
)
.strategyConfig(builder -> builder
.addInclude(TBL_NAMES) // 设置需要生成的表名
.addTablePrefix(TABLE_PREFIX) // 设置过滤表前缀
.entityBuilder() // 设置实体类
.enableFileOverride() // 实体类覆盖
.enableTableFieldAnnotation() // 属性加上说明注释
.enableLombok() // 使用lombok
.serviceBuilder() // 设置服务类
.formatServiceFileName("%sService") // 格式化service类
)
.templateEngine(new FreemarkerTemplateEngine())
.execute();
}
}
运行生成 demo_user 表的对应代码
配置数据库链接
spring:
application:
name: Springboot3-CRUD
#配置数据源
datasource:
url: jdbc:mysql://192.168.1.31:3307/my_db?useSSL=false&useUnicode=true&characterEncoding=utf-8
username: test_usr
password: test_usr#Passw0rd
driver-class-name: com.mysql.cj.jdbc.Driver
hikari:
minimum-idle: 5
maximum-pool-size: 10
max-lifetime: 1800000
idle-timeout: 180000
connection-timeout: 30000
配置 MapperScan 注解
@SpringBootApplication
@MapperScan("org.liurb.**.mapper") // mapper 类路径
public class Springboot3CrudApplication {
public static void main(String[] args) {
SpringApplication.run(Springboot3CrudApplication.class, args);
}
}
测试用例
我们通过单元测试保存一条记录
@SpringBootTest
class Springboot3CrudApplicationTests {
@Resource
DemoUserService demoUserService;
@Test
void contextLoads() {
DemoUser record = new DemoUser();
record.setName("李四");
record.setAge(18);
demoUserService.save(record);
}
}
记录保存成功
分页
分页拦截器配置
@Configuration
public class MybatisPlusConfig {
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
return mybatisPlusInterceptor;
}
}
分页查询大于等于12岁的用户,获取第一页的十条数据
@Test
void contextLoads() {
Page page = new Page(1, 10);
IPage pageRecords = demoUserService.page(page, new LambdaQueryWrapper().ge(DemoUser::getAge, 12));
List records = pageRecords.getRecords();
System.out.println(records);
}
运行截图如下:
sql 打印
查询的结果
创建查询接口
在控制层加入查询接口,根据 用户id 查询对应的记录
@RestController
@RequestMapping("/crud/demoUser")
public class DemoUserController {
@Resource
DemoUserService demoUserService;
@GetMapping("/{userId}")
public DemoUser user(@PathVariable Long userId) {
return demoUserService.getById(userId);
}
}
请求返回