温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

MyBatis-Plus中自动填充功能失效如何解决

发布时间:2021-02-04 16:09:34 来源:亿速云 阅读:2909 作者:Leah 栏目:开发技术

本篇文章给大家分享的是有关MyBatis-Plus中自动填充功能失效如何解决,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

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

以上就是MyBatis-Plus中自动填充功能失效如何解决,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI