mybatisplus的自动填充
时间: 2023-09-01 20:12:49 浏览: 112
MyBatis Plus提供了自动填充(AutoFill)功能,它可以在插入或更新操作时自动填充指定字段的值。这在某些场景下非常有用,比如记录创建时间和更新时间等。
要使用自动填充功能,首先需要定义一个实现了`MetaObjectHandler`接口的类,并在其中实现`insertFill()`和`updateFill()`方法。这两个方法分别用于在插入和更新操作时填充字段的值。
在`insertFill()`方法中,你可以设置需要填充的字段和对应的值。例如,你可以使用`metaObject.setValue()`方法来设置某个字段的值。
在`updateFill()`方法中,你可以设置需要更新的字段和对应的值。同样地,你可以使用`metaObject.setValue()`方法来设置字段的新值。
接下来,需要在实体类的字段上标注注解来指定需要进行自动填充的字段。常用的注解包括`@TableField`和`@TableLogic`。
`@TableField`注解用于指定一个字段需要进行自动填充操作。你可以通过设置`fill`属性为`FieldFill.INSERT`或`FieldFill.UPDATE`来指定在插入或更新操作时进行填充。
以下是一个示例代码:
```java
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
this.setFieldValByName("createTime", new Date(), metaObject);
this.setFieldValByName("updateTime", new Date(), metaObject);
}
@Override
public void updateFill(MetaObject metaObject) {
this.setFieldValByName("updateTime", new Date(), metaObject);
}
}
```
```java
@Data
@Accessors(chain = true)
@TableName("user")
public class UserEntity {
@TableId
private Long id;
private String name;
@TableField(fill = FieldFill.INSERT)
private Date createTime;
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date updateTime;
}
```
在上述示例中,`createTime`字段将在插入操作时进行填充,而`updateTime`字段将在插入和更新操作时进行填充。
需要注意的是,你还需要在配置文件中配置自动填充功能。可以通过在配置文件中添加`meta-object-handler`配置项来指定自定义的`MetaObjectHandler`实现类。
这样设置后,当执行插入或更新操作时,MyBatis Plus会自动调用对应的自动填充方法,并填充相应的字段值。
阅读全文