MyBatis-Plus自動填充字段的詳細教程
1. 項目環(huán)境配置
首先,需要確保項目中已經(jīng)集成了 Spring Boot 和 MyBatis-Plus。下面是一些基本的配置步驟:
1.1 引入必要的依賴
在 pom.xml
中添加 MyBatis-Plus 的依賴:
<dependencies> <!-- MyBatis-Plus --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.5.1</version> </dependency> <!-- 其他必要依賴 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- MySQL 驅(qū)動 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency> </dependencies>
1.2 配置數(shù)據(jù)源
在 application.yml
或 application.properties
文件中配置數(shù)據(jù)庫連接:
spring: datasource: url: jdbc:mysql://localhost:3306/your_database?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC username: your_username password: your_password driver-class-name: com.mysql.cj.jdbc.Driver mybatis-plus: mapper-locations: classpath:/mapper/*.xml type-aliases-package: com.example.entity global-config: db-config: id-type: auto
2. 創(chuàng)建基礎(chǔ)實體類
為數(shù)據(jù)庫中的表創(chuàng)建一個基礎(chǔ)實體類 BaseEntity
,在該類中定義創(chuàng)建時間和更新時間字段,并使用 MyBatis-Plus 的注解配置自動填充。
package com.example.utils; import com.baomidou.mybatisplus.annotation.FieldFill; import com.baomidou.mybatisplus.annotation.TableField; import com.fasterxml.jackson.annotation.JsonIgnore; import com.fasterxml.jackson.annotation.JsonInclude; import lombok.Data; import java.io.Serializable; import java.util.Date; import java.util.HashMap; import java.util.Map; @Data public class BaseEntity implements Serializable { private static final long serialVersionUID = 1L; /** * 搜索值(暫時忽略) */ @JsonIgnore @TableField(exist = false) private String searchValue; /** * 創(chuàng)建者 */ @TableField(fill = FieldFill.INSERT) private String createBy; /** * 創(chuàng)建時間 */ @TableField(fill = FieldFill.INSERT) private Date createTime; /** * 更新者 */ @TableField(fill = FieldFill.INSERT_UPDATE) private String updateBy; /** * 更新時間 */ @TableField(fill = FieldFill.INSERT_UPDATE) private Date updateTime; /** * 請求參數(shù)(暫時忽略) */ @JsonInclude(JsonInclude.Include.NON_EMPTY) @TableField(exist = false) private Map<String, Object> params = new HashMap<>(); }
3. 實現(xiàn) MetaObjectHandler 接口
為了使 BaseEntity
中的自動填充注解生效,我們需要實現(xiàn) MetaObjectHandler
接口,并將其配置為 Spring 的一個 Bean。
3.1 創(chuàng)建 MyMetaObjectHandler 類
package com.example.config; import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler; import org.apache.ibatis.reflection.MetaObject; import org.springframework.stereotype.Component; import java.util.Date; @Component public class MyMetaObjectHandler implements MetaObjectHandler { @Override public void insertFill(MetaObject metaObject) { // 填充創(chuàng)建時間和更新時間 this.strictInsertFill(metaObject, "createTime", Date.class, new Date()); this.strictInsertFill(metaObject, "updateTime", Date.class, new Date()); // 可以根據(jù)業(yè)務(wù)需求獲取當前用戶,填充創(chuàng)建者和更新者 this.strictInsertFill(metaObject, "createBy", String.class, getCurrentUser()); this.strictInsertFill(metaObject, "updateBy", String.class, getCurrentUser()); } @Override public void updateFill(MetaObject metaObject) { // 更新時只填充更新時間和更新者 this.strictUpdateFill(metaObject, "updateTime", Date.class, new Date()); this.strictUpdateFill(metaObject, "updateBy", String.class, getCurrentUser()); } // 示例方法:獲取當前用戶信息 private String getCurrentUser() { // 這里可以集成 Spring Security 或其他上下文獲取實際的當前用戶 return "system"; // 這是一個占位符,實際應(yīng)用中會替換為真實用戶信息 } }
3.2 配置生效
通過在 MyMetaObjectHandler
類上使用 @Component
注解,Spring 會自動管理這個類,并在實體插入和更新時調(diào)用它來填充字段。
4. 實體類繼承 BaseEntity
現(xiàn)在,你的具體實體類可以繼承 BaseEntity
,從而自動獲得 createTime
和 updateTime
字段的自動填充功能。
package com.example.entity; import com.baomidou.mybatisplus.annotation.TableName; import com.example.utils.BaseEntity; import lombok.Data; @Data @TableName("your_table") public class YourEntity extends BaseEntity { // 其他字段 private String name; private Integer age; }
5. 處理數(shù)據(jù)插入與更新
在 Service 或 Mapper 層,執(zhí)行插入或更新操作時,createTime
和 updateTime
字段會自動填充。
5.1 Service 層示例
@Service public class YourEntityService { @Autowired private YourEntityMapper yourEntityMapper; public void saveEntity(YourEntity entity) { yourEntityMapper.insert(entity); } public void updateEntity(YourEntity entity) { yourEntityMapper.updateById(entity); } }
6. 驗證自動填充功能
通過簡單的單元測試或集成測試,驗證 createTime
和 updateTime
字段在插入和更新時是否正確自動填充。
7. 其他注意事項
- 字段類型: 確保數(shù)據(jù)庫中的
createTime
和updateTime
字段類型與 Java 實體類中的類型相匹配(通常是DATETIME
類型)。 - 時間格式: 如果需要統(tǒng)一時間格式,可以在配置文件中設(shè)置 Spring Boot 的全局時間格式,或使用
@JsonFormat
注解指定序列化時的格式。
spring: jackson: date-format: yyyy-MM-dd HH:mm:ss time-zone: GMT+8
總結(jié)
通過本文的教程,你可以輕松地在 Spring Boot 項目中使用 MyBatis-Plus 自動填充創(chuàng)建時間和更新時間字段。該方法充分利用了 MyBatis-Plus 的自動填充機制,并結(jié)合 Spring Boot 的優(yōu)勢,使開發(fā)過程更加簡潔高效。如果遇到問題,務(wù)必檢查 MetaObjectHandler
是否正確注冊,字段類型是否匹配,以及數(shù)據(jù)庫配置是否正確。
以上就是MyBatis-Plus自動填充字段的詳細教程的詳細內(nèi)容,更多關(guān)于MyBatis-Plus自動填充字段的資料請關(guān)注腳本之家其它相關(guān)文章!
- MyBatisPlus實現(xiàn)自動填充字段的實踐
- mybatis-plus調(diào)用update方法時,自動填充字段不生效問題及解決
- MyBatis-Puls插入或修改時某些字段自動填充操作示例
- Mybatis-Plus實現(xiàn)公共字段自動填充的項目實踐
- MyBatis-Plus邏輯刪除和字段自動填充的實現(xiàn)
- MyBatis-Plus實現(xiàn)公共字段自動填充功能詳解
- Mybatis-Plus自動填充更新操作相關(guān)字段的實現(xiàn)
- MyBatis-Plus實現(xiàn)字段自動填充功能的示例
- Mybatis plus通用字段自動填充的示例
- Mybatis攔截器實現(xiàn)公共字段填充的示例代碼
相關(guān)文章
java.net.ConnectException: Connection refused問題解決辦法
這篇文章主要介紹了java.net.ConnectException: Connection refused問題解決辦法的相關(guān)資料,需要的朋友可以參考下2016-12-12淺析如何在SpringBoot中實現(xiàn)數(shù)據(jù)脫敏
脫敏是指在不改變原數(shù)據(jù)結(jié)構(gòu)的前提下,通過某種方式處理數(shù)據(jù),使數(shù)據(jù)不能直接暴露用戶的真實信息,下面我們就來看看SpringBoot中實現(xiàn)數(shù)據(jù)脫敏的具體方法吧2024-03-03SpringBoot整合SpringSecurityOauth2實現(xiàn)鑒權(quán)動態(tài)權(quán)限問題
這篇文章主要介紹了SpringBoot整合SpringSecurityOauth2實現(xiàn)鑒權(quán)-動態(tài)權(quán)限,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06