Mybatis-Plus自动填充的实现示例
生活随笔
收集整理的這篇文章主要介紹了
Mybatis-Plus自动填充的实现示例
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
在常用業(yè)務(wù)中有些屬性需要配置一些默認值,MyBatis-Plus提供了實現(xiàn)此功能的插件。在這里修改user表添加 create_time 字段和 update_time 字段,在User類中添加對應(yīng)屬性。
1、為需要自動填充的屬性添加注解 @TableField
提供了4種自動填充策略:DEFAULT,默認不處理。INSERT,插入填充字段。UPDATE,更新填充字段。INSERT_UPDATE,插入和更新填充字段。
@Data public class User {private Long id;private String name;private Integer age;private String email;@TableField(fill = FieldFill.INSERT)private Date createTime;@TableField(fill = FieldFill.INSERT_UPDATE)private Date updateTime; }2、實現(xiàn)字段填充控制器,編寫自定義填充規(guī)則
實現(xiàn) MetaObjectHandler 接口,實現(xiàn) insertFill 和 updateFill 方法,此處的 create_time 和update_time字段需要插入時填充值, 只有 update_time 字段在修改時需要填充,所以策略如下。
//需要將自定義填充控制器注冊為組件@Component public class MyMetaObjectHandler implements MetaObjectHandler {private static final Logger LOGGER= LoggerFactory.getLogger(MyMetaObjectHandler.class);//insert操作時要填充的字段@Overridepublic void insertFill(MetaObject metaObject) {LOGGER.info("start insert fill ...");//根據(jù)屬性名字設(shè)置要填充的值this.setFieldValByName("createTime",new Date(),metaObject);this.setFieldValByName("updateTime",new Date(),metaObject);}//update操作時要填充的字段@Overridepublic void updateFill(MetaObject metaObject) {LOGGER.info("start insert fill ...");this.setFieldValByName("updateTime",new Date(),metaObject);} }3、插入數(shù)據(jù)測試
@RunWith(SpringRunner.class) @SpringBootTest public class CRUDTest {@Autowiredprivate UserMapper userMapper;@Testpublic void testInsert(){User user = new User();user.setName("jack11");user.setAge(20);user.setEmail("4849111@qq.com");int result= userMapper.insert(user);System.out.println(result);System.out.println(user);} }4、修改數(shù)據(jù)測試
@Test public void testUpdate(){User user = new User();user.setId(2L);user.setName("Jackie");int result = userMapper.updateById(user);System.out.println(result); }一次插入數(shù)據(jù)后,create_time和update_time都被填充了設(shè)置的時間,做update操作后只有update_time的進行了填充修改。
?
總結(jié)
以上是生活随笔為你收集整理的Mybatis-Plus自动填充的实现示例的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: No module named ker
- 下一篇: MyBatis-Plus selectM