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。如有錯誤或未考慮完全的地方,望不吝賜教。
推薦閱讀:
- Mybatis-Plus自動填充更新操作相關字段的實現
- MybatisPlus 插入或更新數據時自動填充更新數據解決方案
- 在MyBatisPlus中使用@TableField完成字段自動填充的操作
- MyBatis-Plus實現字段自動填充功能的示例
- Mybatis-Plus實現公共字段自動賦值的方法