"updateTime", () -> LocalDateTime.now(), LocalDateTime.class); // 起始版本 3.3.3(推荐)// 或者// this.fillStrategy(metaObject, "updateTime", LocalDateTime.now()); // 也可以使用(
方案一:实体更新时,直接使用update(Wrapper<T> updateWrapper)的重载方法boolean update(T entity, Wrapper<T> updateWrapper) 示例: 代码语言:txt 复制 msgLogService.update(new MsgLog(),lambdaUpdateWrapper) 方案二:重写update(Wrapper<T> updateWrapper)方法 重写update的方法思路有如下 方法一:重写ServiceImpl的u...
createdBy 创建人 lastUpdateDate 更新时间 lastUpdateBy 更新人 需要注意的是在触发自动填充之前是要在公共字段中配置枚举类的 @TableField(fill = FieldFill.INSERT)privateLocalDateTime creationDate;@TableField(fill = FieldFill.INSERT)privateString createdBy;@TableField(fill = FieldFill.INSERT_UPDATE)privateL...
在更新数据库的时候,发现update_time字段的自动填充失效了,实体里面的字段的注解是加上了的。 @TableField(value = “update_time”, fill = FieldFill.INSERT_UPDATE) 有可能的原因:mybatis配置文件MyBatisPlusConfig配置了乐观锁,乐观锁会让自动填充失效。 配置乐观锁之后updateById()方法会出现两种情况: 1、从数...
REQUIRED) public void updateBook() {} @Transactional(propagation=Propagation.REQUIRES_NEW) public void updateUser() {} 传播流程: 每日小结 事务会导致多数据源失效,这个大家一定要记清 一定要明白事务的传播特性,开发中其实常用的就只有REQUIRED和REQUIRES_NEW,大家只要把这两个搞明白,就能应对绝大数的问题...
更新自动填充失效 当前使用版本(必填,否则不予处理) 3.4.2 该问题是如何引起的?(确定最新版也有问题再提!!!) 自动填充最后调用接口strictFillStrategy // 严格模式填充策略,默认有值不覆盖,如果提供的值为null也不填充defaultMetaObjectHandlerstrictFillStrategy(MetaObject metaObject, String fieldName, Supplier<?> ...
save()是在接口中定义的default方法,saveOrUpdate()是在实现类中实现的带事务注解@Transactional的方法。 原因及解决方法 因为源码中saveOrUpdate使用了事务,故在Mapper切面设置数据源无效。 对MyBatis-plus的服务包进行切面,代码如下: @Component@Order(value=0)@Slf4j@AspectpublicclassDataSourceAspectOnService{@Valu...
= null"> AND create_user_name=#{ew.entity.createUserName}</if> <if test="ew.entity['updateTime'] != null"> AND update_time=#{ew.entity.updateTime}</if> <if test="ew.entity['updateUserId'] != null"> AND update_user_id=#{ew.entity.updateUserId}</if> <if test="ew.entity...
MyBatis Plus版本:3.0.6 配置 项目中使用shardingjdbc管理数据源,这里只贴其中一个配置 @Bean("tidb...