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); |
![](https://img-blog.csdnimg.cn/img_convert/68530107780f6046fccd95a9dd7197d1.jpeg)
这样可以拿到表相关信息,会执行我们的 metaobjecthandler 实现接口
补充:springboot+mybatisplus 公共字段自动填充 mybatisplusconfig配置不生效解决
springboot+mybatisplus mybatisplusconfig配置不生效问题
先说下工程目录
![](https://img-blog.csdnimg.cn/img_convert/4fdb98c0e0ed32e39cb7807488bfd4b3.jpeg)
典型的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
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。