代驾app系统开发如何推动出行服务的智能化与便捷化
473
2023-04-16
MybatisPlus 自动填充的实现
一、设置填充时机
使用下面的注解设置填充的时机,例如insert 、update语句
@TableField(fill = FieldFill.INSERT)
有下面4种规则
源码
/**
* 字段填充策略枚举类
*
*
* 判断注入的 insert 和 update 的 sql 脚本是否在对应情况下忽略掉字段的 if 标签生成
*
* 判断优先级比 {@link FieldStrategy} 高
*
*
* @author hubin
* @since 2017-06-27
*/
public enum FieldFill {
/**
* 默认不处理
*/
DEFAULT,
/**
* 插入时填充字段
*/
INSERT,
/**
* 更新时填充字段
*/
UPDATE,
/**
* 插入和更新时填充字段
*/
INSERT_UPDATE
}
二、设置填充的值
创建一个类实现mp提供的MetaObjectHandler接口
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
import java.time.LocalDateTime;
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
setFieldValByName("字段名,例如User的createTime", LocalDateTime.now(),metaObject);
}
@Overrihttp://de
public void updateFill(MetaObject metaObject) {
setFieldValByName("字段名,例如User的updateTime",LocalDateTime.now(),metaObject);
}
}
注意请将中文去掉换成自己实体对象的字段名
测试代码:
User usehttp://r = new User();
user.setName("张三");
user.setAge(12);
user.setAge(12);
user.setId(11111111111L);
user.setEmail("someone@qq.com");
user.setManagerId(1087982257332887553L);
int insert = userMapper.insert(user);
System.out.println("插入"+insert);
检测表中数据:
说明成功
优化填充规则
案例代码:
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
import java.time.LocalDateTime;
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObhttp://ject metaObject) {
boolean createTime = metaObject.hasSetter("createTime");//如果有这个字段返回true
if (createTime) {//如果字段不存在则不进行下面的填充
setFieldValByName("createTime", LocalDateTime.now(), metaObject);
}
}
@Override
public void updateFill(MetaObject metaObject) {
Object updateTime = getFieldValByName("updateTime", metaObject);
if (null == updateTime) { //没有设置updateTime值则进行填充如果有设置值则不进行填充
setFieldValByName("updateTime", LocalDateTime.now(), metaObject);
}
}
}
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~