热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

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

这篇文章主要介绍了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.lambdaUpdate()) 这样的写法是没有拦截到的,所以无效

xml 写的也无效

@update 注解也无效

baseMapper.update(null, Wrappers.lambdaUpdate()
.set(Users::getConcernType,2)
.eq(Users::getId,userId));

应该改为

baseMapper.update(users, Wrappers.lambdaUpdate()
.set(Users::getConcernType,2));

或者

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 代码:

/**
 * 实体父类
 */
@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

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


推荐阅读
  • Spring Boot 实战(一):基础的CRUD操作详解
    在《Spring Boot 实战(一)》中,详细介绍了基础的CRUD操作,涵盖创建、读取、更新和删除等核心功能,适合初学者快速掌握Spring Boot框架的应用开发技巧。 ... [详细]
  • Spring框架入门指南:专为新手打造的详细学习笔记
    Spring框架是Java Web开发中广泛应用的轻量级应用框架,以其卓越的功能和出色的性能赢得了广大开发者的青睐。本文为初学者提供了详尽的学习指南,涵盖基础概念、核心组件及实际应用案例,帮助新手快速掌握Spring框架的核心技术与实践技巧。 ... [详细]
  • Spring注解开发指南:@Resource与@Component详解 ... [详细]
  • 深入解析Spring Boot源码的序章
    本系列文章旨在深入解析Spring Boot的源代码,分享笔者在学习过程中的心得与体会。内容涵盖核心源码分析,可能会对初学者造成一定理解难度,建议读者结合笔者提供的详细注释进行阅读,以获得更好的学习体验。 ... [详细]
  • 作为140字符的开创者,Twitter看似简单却异常复杂。其简洁之处在于仅用140个字符就能实现信息的高效传播,甚至在多次全球性事件中超越传统媒体的速度。然而,为了支持2亿用户的高效使用,其背后的技术架构和系统设计则极为复杂,涉及高并发处理、数据存储和实时传输等多个技术挑战。 ... [详细]
  • 本文介绍了如何通过掌握 IScroll 技巧来实现流畅的上拉加载和下拉刷新功能。首先,需要按正确的顺序引入相关文件:1. Zepto;2. iScroll.js;3. scroll-probe.js。此外,还提供了完整的代码示例,可在 GitHub 仓库中查看。通过这些步骤,开发者可以轻松实现高效、流畅的滚动效果,提升用户体验。 ... [详细]
  • 可转债数据智能抓取与分析平台优化
    本项目旨在优化可转债数据的智能抓取与分析平台。通过爬取集思录上的可转债信息(排除已发布赎回的债券),并结合安道全教授提出的三条安全线投资策略,新增了建仓线、加仓线和重仓线,以提供更精准的投资建议。 ... [详细]
  • SQLmap自动化注入工具命令详解(第28-29天 实战演练)
    SQL注入工具如SQLMap等在网络安全测试中广泛应用。SQLMap是一款开源的自动化SQL注入工具,支持12种不同的数据库,具体支持的数据库类型可在其插件目录中查看。作为当前最强大的注入工具之一,SQLMap在实际应用中具有极高的效率和准确性。 ... [详细]
  • 在本文中,我们将探讨如何使用 UniApp 封装小程序 API 请求接口的最佳实践。通过创建 `request.js` 文件,定义基础 URL 并传入后端提供的 URL 作为请求参数。同时,配置请求方法(如 GET、POST)和请求头(例如包含 token 的认证信息),以实现高效、安全的 API 调用。此外,我们还将介绍如何处理请求和响应的错误,以及如何优化请求性能,确保应用在不同平台上的兼容性和稳定性。 ... [详细]
  • 如何在Android应用中设计和实现专业的启动欢迎界面(Splash Screen)
    在Android应用开发中,设计与实现一个专业的启动欢迎界面(Splash Screen)至关重要。尽管Android设计指南对使用Splash Screen的态度存在争议,但一个精心设计的启动界面不仅能提升用户体验,还能增强品牌识别度。本文将探讨如何在遵循最佳实践的同时,通过技术手段实现既美观又高效的启动欢迎界面,包括加载动画、过渡效果以及性能优化等方面。 ... [详细]
  • 本文将深入探讨FastJSON的基础解析机制与自定义JSON处理技巧。通过详细分析FastJSON的核心功能和高级用法,帮助读者掌握高效、灵活的JSON数据处理方法。文中还将分享一些实用的代码示例和最佳实践,助力开发者在实际项目中更好地应用FastJSON。 ... [详细]
  • Django框架进阶教程:掌握Ajax请求的基础知识与应用技巧
    本教程深入探讨了Django框架中Ajax请求的核心概念与实用技巧,帮助开发者掌握异步数据交互的方法,提升Web应用的响应速度和用户体验。通过实例解析,详细介绍了如何在Django项目中高效实现Ajax请求,涵盖从基础配置到复杂场景的应用。 ... [详细]
  • 随着越来越多的应用程序采用JSON格式作为响应数据,基于Spring Framework构建的服务端应用也广泛采用了这一实践。本文将详细介绍如何在Spring 4.x版本的MVC框架中配置和实现HTTP请求返回JSON数据流,涵盖相关配置、依赖管理和代码示例,帮助开发者高效地实现这一功能。 ... [详细]
  • 深入解析MyBatis的高级映射技术
    在前一章节中,我们探讨了MyBatis的基本对象映射方法,其中对象属性与数据库表字段之间实现了直接的一对一映射。然而,在实际开发中,这种简单的映射方式往往难以满足复杂业务需求。本文将深入分析MyBatis的高级映射技术,介绍如何通过配置和注解实现更为灵活的对象与数据库表之间的映射关系,包括嵌套结果、联合查询和动态SQL等高级功能,以提高开发效率和代码可维护性。 ... [详细]
  • 在 Spring Boot 项目中,实现多数据源配置以支持 MySQL 和 Oracle 数据库的 JDBC 集成。通过合理配置 `application.properties` 文件,可以轻松管理不同数据源的连接属性,确保应用能够高效地访问多种数据库系统。具体配置包括端口设置、字符编码以及数据库连接参数等,为开发者提供了灵活的数据访问解决方案。 ... [详细]
author-avatar
刘延庚
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有