使用Mybatis-plus策略自動更新數據庫時間失敗問題解決
引言
在mybatis項目中,我們一般會使用它的插件plus以擴充它的基本查詢功能。另一方面,在阿里巴巴開發(fā)手冊的規(guī)范中也提到,在數據庫表創(chuàng)建的時候,一般會有一個create_time和update_time字段,它們的建表語句往往如下:
'create_time' timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, 'update_time' timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
創(chuàng)建者則是希望在行insert的時候會自動生成create_time,同時在其它行進行修改后,執(zhí)行update操作會自動更新update_time字段。
博主在開發(fā)過程中,首先采用了mybatis plus的selectOne,查詢出某一個對象XXX,并對其某一值進行修改(比如狀態(tài)status從0修改成1),然后想利用數據庫的自動時間更新策略,即ON UPDATE CURRENT_TIMESTAMP去自動修改時間。于是用xxxService.updateById(XXX)。
但是,這樣子的更新方法并不會自動更新時間。因為selectOne出來的對象是有一個明確時間了,然后update的時候就會注入這個原時間。
解決辦法
方法一:
自己書寫數據庫字段策略,進行updateFill(),可以參考:http://www.dbjr.com.cn/article/197456.htm
這種方法的確定其博主也說了“注意這種方式只會在使用Mybatis-plus封裝好的方法時才會有 效,使用自己定義的service并不會生效,這是個坑”。同時,我認為這種方法要求每個表的updateTime都是要在修改的時候改變的。有些情況下,修改個別字段可能不需要改變。在這樣像切面一樣,一刀切的注入感覺靈活性不夠。
方法二:
自己寫原生的update sql,只修改要修改的字段,不更改updateTime字段。這樣子在保存的時候就會自動更新時間了。
方法三:
利用plus提供的注解,在對應的entity的字段注解@TableField中加入update = "now()",其中update = "now()"表示使用數據庫時間,輸出 SQL 為:update 表 set 字段=now() where ...,同時字段 update set 部分注入, 該注解優(yōu)于 el 注解使用。
圖1.注解書寫示意圖
注意:這種方法在執(zhí)行updateById的時候有效,執(zhí)行updateAllColumnById的時候是無效的。updateAllColumnById必須設定時間
總結
我們在生成實體的時候明確知道該表的update_time字段就是要做自動更新的,那就用方法二所述的plus下TableField注解進行更新。同時注意updateAllColumnById的情況就好。
至于方法一采用的insertFill和updateFill,這種適合全部的情況下的切面。除非在早期就明確了,如果是在中后期突然要增加的,務必確保是之前表中沒有采用的字段,否則有的時候沖突了,寫入的時候被串改,會導致很難查詢到數據錯誤來源。
到此這篇關于使用Mybatis-plus策略自動更新數據庫時間失敗問題解決的文章就介紹到這了,更多相關Mybatis-plus自動更新數據庫時間內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java設計模式之觀察者模式(Observer Pattern)詳解
觀察者模式(Observer Pattern)是一種行為型設計模式,它定義了一種一對多的依賴關系,當一個對象的狀態(tài)發(fā)生改變時,所有依賴于它的對象都能夠自動地得到通知并進行更新,本文將詳細的給大家介紹一下Java觀察者模式,需要的朋友可以參考下2023-07-07聊聊SpringBoot的@Scheduled的并發(fā)問題
這篇文章主要介紹了聊聊SpringBoot的@Scheduled的并發(fā)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11什么情況下會出現java.io.IOException?:?Broken?pipe這個錯誤以及解決辦法
這篇文章主要介紹了什么情況下會出現java.io.IOException?:?Broken?pipe這個錯誤以及解決辦法的相關資料,這個錯誤表示通信另一端已關閉連接,常發(fā)生在客戶端關閉連接、網絡超時或資源不足等情況,文中將解決辦法介紹的非常詳細,需要的朋友可以參考下2024-10-10