MyBatis-Plus自動填充功能失效導致的原因及解決

1:先檢查 字段有沒有加上註解 @TableField(fill = FieldFill.INSERT_UPDATE)

@TableField(fill = FieldFill.INSERT_UPDATE)
 private Date updatedTime;

2:有沒有實現 MetaObjectHandler 接口 ,並且加入到 Spring 容器中

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
 
 @Override
 public void insertFill(MetaObject metaObject) {
this.strictInsertFill(metaObject, "createdTime", Date.class, new Date());
this.strictInsertFill(metaObject, "updatedTime", Date.class, new Date());
 }
 
 @Override
 public void updateFill(MetaObject metaObject) {
this.strictUpdateFill(metaObject, "updatedTime", Date.class, new Date());
 }
}

3: @Component 是否掃碼註入進去

4: baseMapper.update(null,Wrappers.<Users>lambdaUpdate()) 這樣的寫法是沒有攔截到的,所以無效

xml 寫的也無效

@update 註解也無效

baseMapper.update(null, Wrappers.<Users>lambdaUpdate()
.set(Users::getConcernType,2)
.eq(Users::getId,userId));

應該改為

baseMapper.update(users, Wrappers.<Users>lambdaUpdate()
.set(Users::getConcernType,2));

或者

Users users = new Users();
users.setId(userId);
users.setConcernType(1);
baseMapper.updateById(users);

這樣可以拿到表相關信息,會執行我們的 MetaObjectHandler 實現接口

補充:SpringBoot+MyBatisPlus 公共字段自動填充 MybatisPlusConfig配置不生效解決

SpringBoot+MyBatisPlus MybatisPlusConfig配置不生效問題

先說下工程目錄

典型的Maven工程,在common中配置MyBatisPlus配置信息,在Base中進行CRUD操作。

遇到的問題:

在MyBatisPlus中配置瞭公共字段(create_time,upate_time),想在插入數據時,自動插入這兩條字段。

配置如下:

AbstractEntity 代碼:

/**
 * 實體父類
 */
@Data
public abstract class AbstractEntity extends Model implements Serializable {
 private static final long serialVersionUID = 1L;
 /**
  * ID
  */
 @TableId
 private String id;
 /**
  * 創建時間
  */
 @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
 @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
 @TableField(value = "create_time", fill = FieldFill.INSERT)
 public Date createTime;
 /**
  * 修改時間
  */
 @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
 @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
 @TableField(value = "update_time", fill = FieldFill.UPDATE)
 public Date updateTime;
}

MetaHandler代碼:

@Slf4j
@Component
public class MetaHandler implements MetaObjectHandler {
 /**
  * 新增數據執行
  * @param metaObject
  */
 @Override
 public void insertFill(MetaObject metaObject) {
  this.setFieldValByName("createTime", new Date(), metaObject);
  this.setFieldValByName("updateTime", new Date(), metaObject);
 }
 /**
  * 更新數據執行
  * @param metaObject
  */
 @Override
 public void updateFill(MetaObject metaObject) {
  this.setFieldValByName("updateTime", new Date(), metaObject);
 }
}

MybatisPlusConfig 代碼:

@Configuration
@MapperScan("com.lyf.account.**.mapper")
public class MybatisPlusConfig {
 /*
  * 分頁插件,自動識別數據庫類型
  * 多租戶,請參考官網【插件擴展】
  */
 @Bean
 public PaginationInterceptor paginationInterceptor() {
  return new PaginationInterceptor();
 }
 @Bean
 public GlobalConfig globalConfig() {
  GlobalConfig globalConfig = new GlobalConfig();
  globalConfig.setMetaObjectHandler(new MetaHandler());
  return globalConfig;
 }
}

配置後,啟動BaseApplication,使用Postman 進行測試,發現數據成功插入,但是創建時間並沒有插入

在MybatisPlusConfig 的 globalConfig.setMetaObjectHandler(new MetaHandler());處打斷點進行調試,發現代碼並沒有執行到這個類 (╯▔皿▔)╯ 檢查 BaseApplication 才發現,沒有在啟動類中掃描該配置文件@。@

以下是修改過的BaseApplication類:

@SpringBootApplication
@ComponentScan({"com.lyf.account.mybatis.config","com.lyf.account.base"})
public class BaseApplication {
 public static void main(String[] args) {
  SpringApplication.run(BaseApplication.class, args);
 }
 @Bean
 public IdWorker idWorker (){
  return new IdWorker(1,1);
 }
}

加入掃描裝配後,再次進行測試,插入數據完美將創建時間加入O(∩_∩)O

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。