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