更新操作和自动填充功能
更新操作
比较简单,实现原理是动态sql
@Test
void updateTest(){
user user = new user();
user.setId(1524653412236517378L);
user.setAge(200);
user.setEmail("2034281742@qq.com");
userMapper.updateById(user); //没有设置ID,不知道更新哪条数据,所以一定要设置ID
}
自动填充
这个主要用于更新时间,和创建时间等,不需要认为设置的字段
- 使用@TableField注解,提示plus哪写字段需要自动填充
public class user {
@TableId(type = IdType.ID_WORKER)
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;
}
- 还没完,我们只是告诉了plus哪些需要填充,但填充的数据从哪里来呢?
这里我们可以实现MetaObjectHandler接口,来填充数据
package top.luoking.Handler;
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
import java.util.Date;
@Slf4j //日志输出
@Component//将MyMetaObjectHandler添加到IOC容器中
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override //插入时填充数据
public void insertFill(MetaObject metaObject) {
log.info("start insert fill ....");
this.setFieldValByName("createTime",new Date(),metaObject);
this.setFieldValByName("updateTime",new Date(),metaObject);
}
@Override//更新时填充数据
public void updateFill(MetaObject metaObject) {
log.info("start update fill ....");
this.setFieldValByName("updateTime",new Date(),metaObject);
}
}
- 测试
@Test
void insertTest(){
user user = new user();
user.setAge(21);
user.setEmail("2034281742@qq.com");
user.setName("小落");
userMapper.insert(user);
}
@Test
void updateTest(){
user user = new user();
user.setId(1524657437254115330L);
user.setAge(200);
user.setEmail("2034281742@qq.com");
userMapper.updateById(user); //没有设置ID,不知道更新哪条数据,所以一定要设置ID
}
insertTest
updateTest
达到了我们理想中的目的,在之后我们就可以利用自动填充来处理时间问题,我个人认为,蛮好用的。