重慶分公司,新征程啟航
為企業提供網站建設、域名注冊、服務器等服務
為企業提供網站建設、域名注冊、服務器等服務
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()); } }