【Mybatis】自动填充其它属性

    <insert id="addAndGet" keyColumn="incr_id" keyProperty="record.incrId" useGeneratedKeys="true">
        <selectKey keyProperty="record.incrId" resultType="long" order="BEFORE">
            select if(max(incr_id) is null, #{delta}, max(incr_id) + #{delta}) as newId from procurement_auto_increment where name = #{record.name} and state = #{record.state}
        </selectKey>

        INSERT INTO procurement_auto_increment (name, state , incr_id)
        values (#{record.name}, #{record.state}, #{delta})
        ON DUPLICATE key update incr_id = if(state = #{record.state}, ifnull(incr_id, 0) + #{delta}, #{delta} ), state = #{record.state}
    </insert>
### MyBatis-Plus 自动填充 功能详解 #### 实现自动填充的关键组件 MyBatis-Plus 提供了 `MetaObjectHandler` 接口来实现字段自动填充功能。通过继承该接口并重写相应的方法,可以在插入或更新操作时自动生成特定字段的值[^2]。 ```java import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler; import org.apache.ibatis.reflection.MetaObject; public class MyMetaObjectHandler implements MetaObjectHandler { @Override public void insertFill(MetaObject metaObject) { this.strictInsertFill(metaObject, "createTime", Date::new); // 插入时填充创建时间 this.strictInsertFill(metaObject, "createBy", () -> getUserId(), Long.class); // 填充创建者ID } @Override public void updateFill(MetaObject metaObject) { this.strictUpdateFill(metaObject, "updateTime", Date::new); // 更新时填充修改时间 this.strictUpdateFill(metaObject, "updateBy", () -> getUserId(), Long.class); // 填充修改者ID } } ``` #### 字段配置方式 为了使某个字段能够被自动填充,在对应的实体类中需要使用 `@TableField` 注解,并指定 `fill` 属性为合适的枚举值(如 `FieldStrategy.NOT_NULL` 或其他策略)。这允许框架识别哪些字段应该参与自动填充逻辑[^3]。 ```java @TableField(fill = FieldFill.INSERT) private Date createTime; // 创建时间 @TableField(fill = FieldFill.UPDATE) private Date updateTime; // 修改时间 ``` #### 启用全局处理器 最后一步是在 Spring Boot 应用程序上下文中注册上述处理程序作为 Bean 组件,从而让整个应用程序都能享受到这一特性带来的便利[^1]。 ```yaml mybatis-plus: global-config: db-config: id-type: auto configuration: handlers: - my.package.MyMetaObjectHandler ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值