注: 主要用于在插入和更新操作时自动填充字段(如创建时间、更新时间等)。它适用于 MyBatis-Plus 的 Mapper 接口和 XML 映射文件 ,但不适用于原生 SQL 写法(如 JDBC、JPA 或直接 SQL 语句)。
自动填充 handler
在项目/global/handler
目录下创建 MyMetaObjectHandler.java
java
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
import java.time.LocalDateTime;
@Component // 必须加上 @Component 注解,让 Spring 管理
public class MyMetaObjectHandler implements MetaObjectHandler {
// 插入时自动填充
@Override
public void insertFill(MetaObject metaObject) {
// 方法一:指定字段名
// this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐)
// 方法二:使用注解方式(更灵活,推荐)
// this.fillStrategy(metaObject, "createTime"); // 也可以使用这种方式,但需要配合注解
// 方法三:通用方式,检查字段是否存在再填充
if (metaObject.hasSetter("createTime")) {
this.setFieldValByName("createTime", LocalDateTime.now(), metaObject);
}
// // 可以添加其他需要在插入时填充的字段,例如 creator
// if (metaObject.hasSetter("creator")) {
// this.setFieldValByName("creator", "SYSTEM", metaObject); // 示例:用 SYSTEM 填充
// }
}
// 更新时自动填充
@Override
public void updateFill(MetaObject metaObject) {
// 更新时填充 updateTime
if (metaObject.hasSetter("updateTime")) {
this.setFieldValByName("updateTime", LocalDateTime.now(), metaObject);
}
// // 可以添加其他需要在更新时填充的字段,例如 updator
// if (metaObject.hasSetter("updator")) {
// this.setFieldValByName("updator", "SYSTEM", metaObject); // 示例:用 SYSTEM 填充
// }
}
}
BaseBean
pojo 集成 BaseBean。在项目/model/pojo
目录下创建 BaseBean.java
java
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.TableField;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.datatype.jsr310.deser.LocalDateTimeDeserializer;
import com.fasterxml.jackson.datatype.jsr310.ser.LocalDateTimeSerializer;
import lombok.Data;
import java.time.LocalDateTime;
@Data
public class BaseBean {
@TableField(fill = FieldFill.INSERT)
private Long createId;
@TableField(fill = FieldFill.INSERT)
@JsonDeserialize(using = LocalDateTimeDeserializer.class)
@JsonSerialize(using = LocalDateTimeSerializer.class)
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
private LocalDateTime createTime;
@TableField(fill = FieldFill.UPDATE)
private Long updateId;
@TableField(fill = FieldFill.UPDATE)
@JsonDeserialize(using = LocalDateTimeDeserializer.class)
@JsonSerialize(using = LocalDateTimeSerializer.class)
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
private LocalDateTime updateTime;
}
application.yml
配置文件
yml
# MyBatis-Plus 配置
mybatis-plus:
configuration:
map-underscore-to-camel-case: true
mapper-locations: classpath*:mapper/*.xml
依赖引用
xml
<!-- MyBatis-Plus 依赖 -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.2</version> <!-- 请替换为最新版本 -->
</dependency>