Mybatis-Plus自动填充的实现示例
在常用业务中有些属性需要配置一些默认值,MyBatis-Plus提供了实现此功能的插件。在这里修改user表添加create_time字段和update_time字段,在User类中添加对应属性。
1、为需要自动填充的属性添加注解@TableField
提供了4种自动填充策略:DEFAULT,默认不处理。INSERT,插入填充字段。UPDATE,更新填充字段。INSERT_UPDATE,插入和更新填充字段。
@Data
publicclassUser{
privateLongid;
privateStringname;
privateIntegerage;
privateStringemail;
@TableField(fill=FieldFill.INSERT)
privateDatecreateTime;
@TableField(fill=FieldFill.INSERT_UPDATE)
privateDateupdateTime;
}
2、实现字段填充控制器,编写自定义填充规则
实现MetaObjectHandler接口,实现insertFill和updateFill方法,此处的create_time和update_time字段需要插入时填充值,只有update_time字段在修改时需要填充,所以策略如下。
//需要将自定义填充控制器注册为组件
@Component
publicclassMyMetaObjectHandlerimplementsMetaObjectHandler{
privatestaticfinalLoggerLOGGER=LoggerFactory.getLogger(MyMetaObjectHandler.class);
//insert操作时要填充的字段
@Override
publicvoidinsertFill(MetaObjectmetaObject){
LOGGER.info("startinsertfill...");
//根据属性名字设置要填充的值
this.setFieldValByName("createTime",newDate(),metaObject);
this.setFieldValByName("updateTime",newDate(),metaObject);
}
//update操作时要填充的字段
@Override
publicvoidupdateFill(MetaObjectmetaObject){
LOGGER.info("startinsertfill...");
this.setFieldValByName("updateTime",newDate(),metaObject);
}
}
3、插入数据测试
@RunWith(SpringRunner.class)
@SpringBootTest
publicclassCRUDTest{
@Autowired
privateUserMapperuserMapper;
@Test
publicvoidtestInsert(){
Useruser=newUser();
user.setName("jack11");
user.setAge(20);
user.setEmail("4849111@qq.com");
intresult=userMapper.insert(user);
System.out.println(result);
System.out.println(user);
}
}
4、修改数据测试
@Test
publicvoidtestUpdate(){
Useruser=newUser();
user.setId(2L);
user.setName("Jackie");
intresult=userMapper.updateById(user);
System.out.println(result);
}
一次插入数据后,create_time和update_time都被填充了设置的时间,做update操作后只有update_time的进行了填充修改。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。