MyBatis-Plus自動(dòng)填充功能失效導(dǎo)致的原因及解決
1:先檢查 字段有沒(méi)有加上注解 @TableField(fill = FieldFill.INSERT_UPDATE)
@TableField(fill = FieldFill.INSERT_UPDATE) private Date updatedTime;
2:有沒(méi)有實(shí)現(xiàn) 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 是否掃碼注入進(jìn)去
4: baseMapper.update(null,Wrappers.<Users>lambdaUpdate()) 這樣的寫(xiě)法是沒(méi)有攔截到的,所以無(wú)效
xml 寫(xiě)的也無(wú)效
@update 注解也無(wú)效
baseMapper.update(null, Wrappers.<Users>lambdaUpdate() .set(Users::getConcernType,2) .eq(Users::getId,userId));
應(yīng)該改為
baseMapper.update(users, Wrappers.<Users>lambdaUpdate() .set(Users::getConcernType,2));
或者
Users users = new Users(); users.setId(userId); users.setConcernType(1); baseMapper.updateById(users);
這樣可以拿到表相關(guān)信息,會(huì)執(zhí)行我們的 MetaObjectHandler 實(shí)現(xiàn)接口
補(bǔ)充:SpringBoot+MyBatisPlus 公共字段自動(dòng)填充 MybatisPlusConfig配置不生效解決
SpringBoot+MyBatisPlus MybatisPlusConfig配置不生效問(wèn)題
先說(shuō)下工程目錄
典型的Maven工程,在common中配置MyBatisPlus配置信息,在Base中進(jìn)行CRUD操作。
遇到的問(wèn)題:
在MyBatisPlus中配置了公共字段(create_time,upate_time),想在插入數(shù)據(jù)時(shí),自動(dòng)插入這兩條字段。
配置如下:
AbstractEntity 代碼:
/** * 實(shí)體父類(lèi) */ @Data public abstract class AbstractEntity extends Model implements Serializable { private static final long serialVersionUID = 1L; /** * ID */ @TableId private String id; /** * 創(chuàng)建時(shí)間 */ @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; /** * 修改時(shí)間 */ @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 { /** * 新增數(shù)據(jù)執(zhí)行 * @param metaObject */ @Override public void insertFill(MetaObject metaObject) { this.setFieldValByName("createTime", new Date(), metaObject); this.setFieldValByName("updateTime", new Date(), metaObject); } /** * 更新數(shù)據(jù)執(zhí)行 * @param metaObject */ @Override public void updateFill(MetaObject metaObject) { this.setFieldValByName("updateTime", new Date(), metaObject); } }
MybatisPlusConfig 代碼:
@Configuration @MapperScan("com.lyf.account.**.mapper") public class MybatisPlusConfig { /* * 分頁(yè)插件,自動(dòng)識(shí)別數(shù)據(jù)庫(kù)類(lèi)型 * 多租戶(hù),請(qǐng)參考官網(wǎng)【插件擴(kuò)展】 */ @Bean public PaginationInterceptor paginationInterceptor() { return new PaginationInterceptor(); } @Bean public GlobalConfig globalConfig() { GlobalConfig globalConfig = new GlobalConfig(); globalConfig.setMetaObjectHandler(new MetaHandler()); return globalConfig; } }
配置后,啟動(dòng)BaseApplication,使用Postman 進(jìn)行測(cè)試,發(fā)現(xiàn)數(shù)據(jù)成功插入,但是創(chuàng)建時(shí)間并沒(méi)有插入
在MybatisPlusConfig 的 globalConfig.setMetaObjectHandler(new MetaHandler());處打斷點(diǎn)進(jìn)行調(diào)試,發(fā)現(xiàn)代碼并沒(méi)有執(zhí)行到這個(gè)類(lèi) (╯▔皿▔)╯ 檢查 BaseApplication 才發(fā)現(xiàn),沒(méi)有在啟動(dòng)類(lèi)中掃描該配置文件@。@
以下是修改過(guò)的BaseApplication類(lèi):
@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); } }
加入掃描裝配后,再次進(jìn)行測(cè)試,插入數(shù)據(jù)完美將創(chuàng)建時(shí)間加入O(∩_∩)O
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
Spring使用Jackson實(shí)現(xiàn)轉(zhuǎn)換XML與Java對(duì)象
這篇文章主要為大家詳細(xì)介紹了Spring如何使用Jackson實(shí)現(xiàn)轉(zhuǎn)換XML與Java對(duì)象,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02Java在PowerPoint幻燈片中創(chuàng)建散點(diǎn)圖的方法
散點(diǎn)圖是通過(guò)兩組數(shù)據(jù)構(gòu)成多個(gè)坐標(biāo)點(diǎn),考察坐標(biāo)點(diǎn)的分布,判斷兩變量之間是否存在某種關(guān)聯(lián)或總結(jié)坐標(biāo)點(diǎn)的分布模式,這篇文章主要介紹了Java如何在PowerPoint幻燈片中創(chuàng)建散點(diǎn)圖,需要的朋友可以參考下2023-04-04解決引用jip-common jar包,報(bào)401 Unauthorized錯(cuò)誤問(wèn)題
這篇文章主要介紹了解決引用jip-common jar包,報(bào)401 Unauthorized錯(cuò)誤問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03Springboot初始化項(xiàng)目并完成登入注冊(cè)的全過(guò)程
工作之余,想要學(xué)習(xí)一下SpringBoot,通過(guò)網(wǎng)絡(luò)大量教程最終成功運(yùn)行SpringBoot項(xiàng)目,下面這篇文章主要給大家介紹了關(guān)于Springboot初始化項(xiàng)目并完成登入注冊(cè)的相關(guān)資料,需要的朋友可以參考下2022-10-10java讀取圖片并轉(zhuǎn)化為二進(jìn)制字符串的實(shí)現(xiàn)方法
這篇文章主要介紹了java讀取圖片并轉(zhuǎn)化為二進(jìn)制字符串的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09