亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SQL語句中如何實現公共字段的自動填充方法

發布時間:2021-05-14 10:06:17 來源:億速云 閱讀:401 作者:小新 欄目:數據庫

這篇文章主要介紹了SQL語句中如何實現公共字段的自動填充方法,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

1. 前言

我們在設計數據庫的時候一定會帶上新增、更新的時間、操作者等審計信息。 之所以帶這些信息是因為假如有一天公司的數據庫被人為刪了,盡管可能有數據庫備份可以恢復數據。但是我們仍然需要追蹤到這個事是誰干的,在什么時間干的,具體干了哪些事等等,方便定責和修補。但是我們變更每條數據都要去顯式變更這些信息就十分繁瑣,我們希望無感知的來處理這些信息。

2. 通用方式

那么有什么好的解決思路呢?在Spring Data框架中提供@CreatedBy和@LastModifiedBy來捕捉誰創建或修改的實體以及@CreatedDate和@LastModifiedDate來捕捉合適創建或修改了實體。如果你使用相關的框架就可以使用這些特性。那么其實我們知道國內Spring Data JDBC、Spring Data JPA并不是主流,主流的是Mybatis。那么我們有哪些選擇?

2.1 開發Mybatis審計插件

如果你使用了原生的Mybatis可以編寫一個審計插件來實現這些功能。我在之前講解過Mybatis插件的教程,并不是非常難的事。如果你想拿來就用,其實GitHub上提供了很多可供選擇的Mybatis審計組件,本來我打算手寫一個,但是確實人家寫的好。你可以通過關鍵詞Mybatis Audit來搜索到它們選擇一款最適合你的。

2.2 Mybatis Plus 自動填充

如果你使用了Mybatis Plus,可以借助于其自動填充功能來實現。

基于 Mybatis Plus 3.3.0

只需要實現MetaObjectHandler接口:

@Component
public class MybatisAuditHandler implements MetaObjectHandler {
 @Override
 public void insertFill(MetaObject metaObject) {
  // 聲明自動填充字段的邏輯。
  String userId = AuthHolder.getCurrentUserId();
  this.strictInsertFill(metaObject,"creator",String.class, userId);
  this.strictInsertFill(metaObject,"createTime", LocalDateTime.class,LocalDateTime.now());
 }

 @Override
 public void updateFill(MetaObject metaObject) {
  // 聲明自動填充字段的邏輯。
  String userId = AuthHolder.getCurrentUserId();
  this.strictUpdateFill(metaObject,"updater",String.class,userId);
  this.strictUpdateFill(metaObject,"updateTime", LocalDateTime.class,LocalDateTime.now());
 }
}

然后我們擴展一下Mybatis Plus的Model<T>把公共審計字段放進去并聲明對應的填充策略:

public abstract class BaseEntity<T extends Model<?>> extends Model<T> {

 @TableField(fill = FieldFill.INSERT)
 private String creator;
 @TableField(fill = FieldFill.INSERT)
 private LocalDateTime addTime;
 @TableField(fill = FieldFill.UPDATE)
 private String updater;
 @TableField(fill = FieldFill.UPDATE)
 private LocalDateTime updateTime;
}

最后我們的實體類不再直接繼承Model<T>改為上面的BaseEntity<T>:

@Data
@EqualsAndHashCode(callSuper = false)
public class UserInfo extends BaseEntity<UserInfo> {
 @TableId(value = "user_id", type = IdType.ASSIGN_ID)
 private String userId;
 private String username;

 @Override
 protected Serializable pkVal() {
  return this.userId;
 }
}

這樣我們就不用再關心這幾個公共字段了,當然你可以根據需要添加更多你需要填充的字段。

感謝你能夠認真閱讀完這篇文章,希望小編分享的“SQL語句中如何實現公共字段的自動填充方法”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巴中市| 科技| 延吉市| 冕宁县| 比如县| 勐海县| 资溪县| 宝坻区| 广宁县| 赤峰市| 浠水县| 同心县| 阿城市| 桐柏县| 开远市| 环江| 奉贤区| 元谋县| 台中市| 梅河口市| 利津县| 沁阳市| 夏邑县| 莱西市| 渝中区| 盐亭县| 永安市| 长沙县| 亳州市| 阜城县| 那坡县| 泰州市| 阿图什市| 凌云县| 依安县| 古丈县| 长乐市| 柳州市| 股票| 呼和浩特市| 密云县|