我們在日常開發中經常使用ORM框架,比如Mybatis、tk.Mybatis、Mybatis-Plus。不過最廣泛的還是Mybatis-Plus,我們的一些表,都會有建立時間、更新時間、建立人、更新人。這些我們每次都要自己手動set吃力不討好,所以Mybatis-Plus帶來了自動填充,今天小編帶大家一起學習一下,本次以填充日期為例哈!!學到的小夥伴記得一鍵三連哦~~
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.1</version>
</dependency>
@Data
public class Test implements Serializable {
private static final long serialVersionUID = 337361630075002456L;
@TableId(type= IdType.ASSIGN_ID)
private long id;
private String name;
private String gender;
private String phone;
@TableField(value = "create_date",fill = FieldFill.INSERT)
private LocalDateTime createDate;
@TableField(value = "update_date",fill = FieldFill.UPDATE)
private LocalDateTime updateDate;
}
@Slf4j
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
log.info("start insert fill ....");
this.strictInsertFill(metaObject, "createDate", LocalDateTime.class, LocalDateTime.now());
}
@Override
public void updateFill(MetaObject metaObject) {
log.info("start update fill ....");
this.strictUpdateFill(metaObject, "updateDate", LocalDateTime.class, LocalDateTime.now());
}
}
@RestController
@RequestMapping("/test")
@Slf4j
@RequiredArgsConstructor
public class TestController {
@NonNull
private TestMapper testMapper;
@GetMapping("/insert")
public Result insert(@RequestBody Test test){
testMapper.insert(test);
return Result.success("插入成功");
}
@PutMapping("/update")
public Result update(@RequestBody Test test){
testMapper.updateById(test);
return Result.success("插入成功");
}
}
友情提示:
這個@RequiredArgsConstructor
註解不明白的看我這篇文章哦!---> @RequiredArgsConstructor註解
請求地址:localhost:8089/test/insert
請求內容:
{
"name":"王",
"gender":"男",
"phone":"123"
}
我們可以看到沒有輸入日期,自動建立了哈!!
請求地址:localhost:8089/test/update
請求內容:
{
"id":14,
"name":"王",
"gender":"男",
"phone":"123"
}
此時我們看到更新也是可以自動填充的!!
總的來說還是比較方便的,減輕開發的工作量,程式碼更加優雅哈!
特別提醒:自動填充的型別要和實體類的型別一致,不然不會填充哈!!
喜歡小編的記得關注一波哦!!