MyBatis-plus自动填充
程序员hg 人气:0什么是自动填充
有些表中会有更新时间、创建时间、更新人或者创建人这些字段。
每次对数据进行新增、删除、修改时都需要对这些字段进行设置。传统的做法是在进行这些操作前,对Entity的字段进行set设置,然后再进行操作。这种做法不仅容易忘记导致出错、而且代码会显得特别冗余。
虽然新增时间和修改时间可以使用数据库的时间,但是新增人和修改人就不能使用这样的功能。
所以MP就提供自动填充的功能,帮助自定设置这些字段的值,提升开发效率,代码也会显得特别优雅。
1.这个功能是做什么的呢?
有的时候,我们可能有这样子的需求,在插入(insert)或者更新数据(update)的时候可以自动填充数据,比如密码,version等。在mp中为我们提供了这种功能,非常的方便!
2.下面用一个例子来学习这个功能
2.1添加注解@TableField(),这个注解里面的fill提供了填充的功能
@TableField(fill = FieldFill.INSERT) //插入时进行填充 private String password;
FirledFill提供了以下几种模式,根据情况可以自己进行选择
public enum FieldFill { DEFAULT, //默认不进行处理 INSERT, //插入的时候填充字段 UPDATE, //更新的时候填充字段 INSERT_UPDATE; //插入和更新的时候填充字段 private FieldFill() { //构造方法 } }
2.2编写MyMetaObjectorHandler,实现源对象字段填充控制器抽象类,根据需求实不同的方法,这里是实现一个插入填充的方法
public class MyMetaObjectHandler implements MetaObjectHandler { //插入填充 @Override public void insertFill(MetaObject metaObject) { Object password = getFieldValByName("password", metaObject); if (ObjectUtils.isNull(password)) { setFieldValByName("password", "88888888", metaObject); } } //更新填充 @Override public void updateFill(MetaObject metaObject) { } }
2.3将自定义的MyObjectHandler进行bean注入MybatisPlusConfig中
@Configuration public class MybatisPlusConfig { @Bean //插入填充 public MyMetaObjectHandler myMetaObjectHandler(){ return new MyMetaObjectHandler(); } }
3.测试
@Test public void test() { User user = new User(); user.setAge(29); user.setEmail("test@163.com"); user.setUserName("guanyu"); user.setName("关羽"); user.setAddress("上海"); // user.setPassword("123456"); //将密码进行注释,如果插入填充生效的话,数据库默认就填充了上面的88888888为password的值 int result = userMapper.insert(user); System.out.println("result=" + result); System.out.println(user.getId()); }
4.结果
综上所示,自动填充成功。
加载全部内容