欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MyBatis-Plus自动填充功能失效导致的原因及解决

程序员文章站 2022-03-20 18:29:20
1:先检查 字段有没有加上注解 @tablefield(fill = fieldfill.insert_update)@tablefield(fill = fieldfill.insert_updat...

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);

MyBatis-Plus自动填充功能失效导致的原因及解决

这样可以拿到表相关信息,会执行我们的 metaobjecthandler 实现接口

补充:springboot+mybatisplus 公共字段自动填充 mybatisplusconfig配置不生效解决

springboot+mybatisplus mybatisplusconfig配置不生效问题

先说下工程目录

MyBatis-Plus自动填充功能失效导致的原因及解决

典型的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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。