關(guān)于Mybatis-Plus字段策略與數(shù)據(jù)庫自動(dòng)更新時(shí)間的一些問題
字段策略 0:”忽略判斷”,1:”非 NULL 判斷”),2:”非空判斷”
問題描述:
當(dāng)字段策略為 0 “忽略判斷” 的時(shí)候,如果實(shí)體和數(shù)據(jù)庫有字段是需要自動(dòng)更新的,例如update_time,更新某條記錄的時(shí)候自動(dòng)刷新update_time,理論上我們在業(yè)務(wù)控制的時(shí)候是不需要設(shè)置update_time的,利用數(shù)據(jù)庫特性就好,但是在該字段策略下,業(yè)務(wù)邏輯要更新字段(沒有主動(dòng)設(shè)置 update_time),這時(shí)候因?yàn)楹雎耘袛啵瑪?shù)據(jù)庫(我這里是MySql)是不會(huì)去更新update_time的,即使這個(gè)字段在數(shù)據(jù)庫中是這樣定義的:update_time datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE,在這種字段策略下,該字段會(huì)被設(shè)為null,具體的執(zhí)行語句時(shí)insert into table(….,update_time) values(…,null)。
解決方法
實(shí)現(xiàn)MetaObjectHandler的insertFill()方法和updateFill()方法
@Component
public class MyMetaObjectHandler extends MetaObjectHandler {
//新增填充
@Override
public void insertFill(MetaObject metaObject){
// 獲取當(dāng)前時(shí)間,自動(dòng)更新以下數(shù)據(jù)庫字段
setFieldValByName("updateTime", new Date(), metaObject);
}
//更新填充
@Override
public void updateFill(MetaObject metaObj ct) {
// 獲取當(dāng)前時(shí)間,自動(dòng)更新以下數(shù)據(jù)庫字段
setFieldValByName("updateTime", new Date(), metaObject);
}
}
新增一個(gè)Component,繼承MetaObjectHandler,重寫 insertFill()和updateFill()兩個(gè)方法,自定義插入和更新規(guī) 則,繼承基類中的這兩個(gè)方法都為空。
注意這種方式只會(huì)在使用Mybatis-plus封裝好的方法時(shí)才會(huì)有 效,使用自己定義的service并不會(huì)生效,這是個(gè)坑,所以這種 方式我并不推薦。
將字段策略設(shè)為 2 “非空判斷”
這時(shí)候,無論是插入還是更新語句都只會(huì)完成對已設(shè)置具體值得屬性進(jìn)行操作。例如:表中除了update_time以外,還有user_name字段,我們在代碼中設(shè)置了這個(gè)字段的值,那么在insert的時(shí)候執(zhí)行的語句是: insert into table (user_name) valuse(userName),而不會(huì)去對沒有設(shè)置值得字段做任何操作,這樣,有關(guān)時(shí)間的字段就可以直接交給數(shù)據(jù)庫了。
字段策略為 ““非空判斷”” 的一個(gè)問題
假設(shè)有個(gè)Entity User,這個(gè)Entity屬性沒有默認(rèn)值,我們 new 一個(gè)實(shí)例,User user = new User(),然后啥也沒做,調(diào)用UserService.insert(),這時(shí)候就會(huì)出現(xiàn)一個(gè)問題,Mybatis-plus不知道你想插入哪些值,因?yàn)闆]有顯示setter,這是一個(gè)需要注意的問題。
到此這篇關(guān)于關(guān)于Mybatis-Plus字段策略與數(shù)據(jù)庫自動(dòng)更新時(shí)間的一些問題的文章就介紹到這了,更多相關(guān)Mybatis-Plus 字段策略內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于Java中String創(chuàng)建的字符串對象內(nèi)存分配測試問題
這篇文章主要介紹了Java中String創(chuàng)建的字符串對象內(nèi)存分配測試,給大家詳細(xì)介紹了在創(chuàng)建String對象的兩種常用方法比較,通過示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-07-07
Maven將代碼及依賴打成一個(gè)Jar包的方式詳解(最新推薦)
這篇文章主要介紹了Maven將代碼及依賴打成一個(gè)Jar包的方式,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05
SpringBoot利用觀察者模式實(shí)現(xiàn)聯(lián)動(dòng)更新機(jī)制
觀察者模式(Observer Pattern)是一種軟件設(shè)計(jì)模式,在許多應(yīng)用系統(tǒng)中,我們經(jīng)常需要處理多個(gè)表之間的關(guān)聯(lián)更新問題,本文將通過一個(gè)具體的案例,介紹如何在Spring Boot項(xiàng)目中利用觀察者模式來優(yōu)雅地解決這一需求,需要的朋友可以參考下2024-07-07

