上一章已经介绍了项目基础框架的搭建,这一章我们介绍项目用到mybatis-Plus如何和springboot整合。
1. common工程pom.xml引入mybatis-Plus 依赖
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.3</version>
</dependency>
还需要引入相应的 mysql连接驱动依赖和数据源连接池依赖,因为上一章已经贴出了所有需要的依赖所有就不在赘述了
2. common工程添加mybatis-Plus 分页插件配置
如果我们想使用mybatis-Plus分页查询需要添加一个配置类,加入分页拦截器配置
package com.swh.common.config;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.transaction.annotation.EnableTransactionManagement;
/**
* @ClassName: MybatisPlusConfig
* @Description:
* @Author: songWenHao
* @Date: 2022/5/30 13:33
*/
@Configuration
@EnableTransactionManagement
public class MybatisPlusConfig {
/**
* 分页插件
*/
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
return interceptor;
}
}
3. common工程添加mybatis-Plus自动填充数据
mybatis-Plus也支持自动填充数据 想一般createTime 和 updateTime 我们都是自动填充的,需要添加一个配置类
package com.swh.common.config;
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
import java.util.Date;
/**
* @ClassName: MyMetaObjectHandler
* @Description:
* @Author: songWenHao
* @Date: 2022/5/30 14:47
*/
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
/**
* 新增填充创建时间、操作人
*
* @param metaObject
*/
@Override
public void insertFill(MetaObject metaObject) {
this.strictInsertFill(metaObject, "createTime", Date::new, Date.class);
this.strictUpdateFill(metaObject, "updateTime", Date::new, Date.class);
}
/**
* 更新填充更新时间、操作人
*
* @param metaObject
*/
@Override
public void updateFill(MetaObject metaObject) {
this.strictUpdateFill(metaObject, "updateTime", Date::new, Date.class);
}
}
package com.swh.common.config;
import com.baomidou.mybatisplus.core.config.GlobalConfig;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
/**
* @ClassName: CommonConfig
* @Description:
* @Author: songWenHao
* @Date: 2022/5/30 14:22
*/
@Configuration
public class CommonConfig {
/**
* 自动填充数据库创建人、创建时间、更新人、更新时间
*/
@Bean
public GlobalConfig globalConfig() {
GlobalConfig globalConfig = new GlobalConfig();
globalConfig.setMetaObjectHandler(new MyMetaObjectHandler());
return globalConfig;
}
}
具体添加配置目录如图所示
4. 关于mybatis-Plus id 生成策略
mybatis-Plus提供了五种生成Id的策略,可以根据你的具体需求选择你需要的策略
public enum IdType {
AUTO(0),# 自动增长策略
NONE(1),#无状态
INPUT(2),#自定义输入策略
ASSIGN_ID(3),#雪花算法
ASSIGN_UUID(4);#不含中划线的UUID
可以直接在实体上加入生成策略
@Data
public class TestVo extends BaseVo {
@TableId(type = IdType.AUTO)
private Integer id;
}
也可以在application.yml配置文件中全局定义生成策略
mybatis-plus:
configuration:
map-underscore-to-camel-case: true
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
global-config:
db-config:
id-type: AUTO
到此mybatis-Plus整合完成了。