🧑🎓 个人主页:Silence Lamb
📖 本章内容:【MyBatisPlus自动填充失效】
📢💨如果文章对你有帮助【关注👍点赞❤️收藏⭐】
问题描述
- 🥭问题一:数据库中需要自动填充的
字段已经有值导致填充失败
–只需要更改填充策略 - 🍓问题二:在配置
Mybatis支持*匹配扫描包
操作执行之后进入不到MyMetaHandler
中导致填充失败需要在sessionFactoryBean
设置globalConfig
问题一:解决方案
- 🌳填充配置
@ApiModelProperty(value = "创建时间")
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@TableField(fill = FieldFill.INSERT)
private LocalDateTime createTime;
@ApiModelProperty(value = "更新者")
private String updateBy;
@ApiModelProperty(value = "更新时间")
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@TableField(fill = FieldFill.INSERT_UPDATE)
private LocalDateTime updateTime;
/**
* @Author: 花棉袄
* @CreateDate: 2022年08月20日
* @Describe: 自动填充
*/
@Slf4j
@Component
public class MyMetaHandler implements MetaObjectHandler {
/**
* 插入元对象字段填充(用于插入时对公共字段的填充)
*
* @param metaObject 元对象
*/
@Override
public void insertFill(MetaObject metaObject) {
log.info("start insert createTime updateTime status");
this.strictInsertFill(metaObject, "createTime", LocalDateTime::now, LocalDateTime.class);
this.strictInsertFill(metaObject, "updateTime", LocalDateTime::now, LocalDateTime.class);
this.strictInsertFill(metaObject, "loginDate", LocalDateTime::now, LocalDateTime.class);
}
/**
* 更新元对象字段填充(用于更新时对公共字段的填充)
*
* @param metaObject 元对象
*/
@Override
public void updateFill(MetaObject metaObject) {
log.info("start update updateTime");
this.strictUpdateFill(metaObject, "updateTime", LocalDateTime::now, LocalDateTime.class);
this.strictUpdateFill(metaObject, "loginDate", LocalDateTime::now, LocalDateTime.class);
}
}
- 🌳填充策略
// 这个是通用的,插入和更新都可以使用 但是当字段存在值 的时候不进行填充
this.fillStrategy(metaObject, "createTime", LocalDateTime.now()); // 也可以使用(3.3.0 该方法有bug请升级到之后的版本如`3.3.1.8-SNAPSHOT`)
// 这个是insert的时候用的,插入的时候时候强制进行填充
this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐使用)
// update的时候使用,更新的时候强制进行填充
this.strictUpdateFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐使用)
- 🌳 源码解析
问题二:解决方案
- 🌳MapperConfig 配置文件
@Configuration
@EnableAspectJAutoProxy(exposeProxy = true)//表示通过aop框架暴露该代理对象,AopContext能够访问
@MapperScan("com.michale.**.mapper")
@ComponentScan(basePackages = "com.michale")
@EnableTransactionManagement
public class MapperConfig {
}
- 🌳添加GlobalConfig 配置
@Bean
public GlobalConfig globalConfig() {
GlobalConfig globalConfig = new GlobalConfig();
globalConfig.setMetaObjectHandler(new MyMetaHandler());
globalConfig.setBanner(false);
return globalConfig;
}
- 🌳 MyBatisConfig引入GlobalConfig
🏅 全栈小狐狸的逆袭之路:📢💨Java学习路线