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);
这样可以拿到表相关信息,会执行我们的 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
以上为个人经验,希望能给大家一个参考,也希望大家多多支持小牛知识库。如有错误或未考虑完全的地方,望不吝赐教。
本文向大家介绍Mybatis-Plus自动填充的实现示例,包括了Mybatis-Plus自动填充的实现示例的使用技巧和注意事项,需要的朋友参考一下 在常用业务中有些属性需要配置一些默认值,MyBatis-Plus提供了实现此功能的插件。在这里修改user表添加 create_time 字段和 update_time 字段,在User类中添加对应属性。 1、为需要自动填充的属性添加注解 @Table
本文向大家介绍listView的item中有checkbox,导致setOnItemClick失效的原因及解决办法,包括了listView的item中有checkbox,导致setOnItemClick失效的原因及解决办法的使用技巧和注意事项,需要的朋友参考一下 一:item的根布局设置 Android:clickable="true",之后导致item点击事件失效,对根布局设置android:
本文向大家介绍Mybatis 缓存原理及失效情况解析,包括了Mybatis 缓存原理及失效情况解析的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了Mybatis 缓存原理及失效情况解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1、什么是缓存[Cache] 存在内存中的临时数据。 将用户经常查询的数据放在缓存(内存)中,用户去查询
本文向大家介绍springboot2.3 整合mybatis-plus 高级功能及用法详解,包括了springboot2.3 整合mybatis-plus 高级功能及用法详解的使用技巧和注意事项,需要的朋友参考一下 —学习并使用mybatis-plus的一些高级功能的用法例如: AR模式、 乐观锁 、逻辑删除 、自动填充、数据保护等功能 为了方便演示,咱们还是新建一个全新的项目 引入mp依赖 ym
本文向大家介绍MyBatis缓存功能原理及实例解析,包括了MyBatis缓存功能原理及实例解析的使用技巧和注意事项,需要的朋友参考一下 缓存 1、简介 查询 : 连接数据库,耗资源! 一次查询的结果,给他暂存在一个可以直接取到的地方!--->内存 : 缓存 我们再次查询相同数据的时候,直接走缓存,就不用走数据库了 什么是缓存: 存在内存中的临时数据 将用户经常查询的数据放在缓存(内存)中,用户去查
问题内容: 这是我目前拥有的东西,不幸的是,我似乎无法弄清楚如何使用jQuery-UI …它曾经与直接的Autocomplete.js一起使用 我在后端的JSON看起来像这样 我使用了这里的答案来使mustMatch正常工作,但是不幸的是,如果我在输入框中“跳格”,或者如果我完全键入单词而不是实际选择建议的文本,那么我会得到“没有选择”响应,而不是值和ID。 当您实际上没有选择字段时,有人知道如何