1:先檢查 字段有沒有加上注解 @tablefield(fill = fieldfill.insert_update)
1
2
|
@tablefield (fill = fieldfill.insert_update) private date updatedtime; |
2:有沒有實現 metaobjecthandler 接口 ,并且加入到 spring 容器中
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
@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 注解也無效
1
2
3
|
basemapper.update( null , wrappers.<users>lambdaupdate() .set(users::getconcerntype, 2 ) .eq(users::getid,userid)); |
應該改為
1
2
|
basemapper.update(users, wrappers.<users>lambdaupdate() .set(users::getconcerntype, 2 )); |
或者
1
2
3
4
|
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 代碼:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
/** * 實體父類 */ @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代碼:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
@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 代碼:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
@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類:
1
2
3
4
5
6
7
8
9
10
11
|
@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
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。如有錯誤或未考慮完全的地方,望不吝賜教。
原文鏈接:https://blog.csdn.net/publicv/article/details/108582719