Mybatis?saveAndUpdate空值不更新問題及解決
Mybatis saveAndUpdate空值不更新
@TableField注解有三種更新策略
public enum FieldStrategy {
? ? IGNORED,//參數(shù)為空也更新到數(shù)據(jù)庫
? ? NOT_NULL,//參數(shù)不能為null
? ? NOT_EMPTY;//參數(shù)不能為空
? ? private FieldStrategy() {
? ? }
}如下,如果想要name字段為空或者null時(shí)也更新數(shù)據(jù)庫數(shù)據(jù),注解上加 strategy = FieldStrategy.IGNORED
@TableField(strategy = FieldStrategy.IGNORED,value="name") ? ? private String name;
Mybatis使用update更新值為null時(shí)不生效
純屬記錄使用過程中遇到的問題更新null值沒有生效的問題解決辦法,內(nèi)容較為簡(jiǎn)單。
出現(xiàn)的問題
前端修改數(shù)據(jù)時(shí)把屬性內(nèi)容刪除然后進(jìn)行保存,默認(rèn)傳的null,后端更新時(shí)屬性值為null,然后調(diào)用updateById進(jìn)行更新時(shí)發(fā)現(xiàn)該屬性還是原來的值:
name:"tt";
//前端頁面把該屬性內(nèi)容進(jìn)行刪除傳給我后端
{
name: null
}
//后端接收到的
name: null
//使用該方法進(jìn)行更新
updateById();
//結(jié)果name還是等于更新前的值
name: "tt";后面百度發(fā)現(xiàn)該update方法不會(huì)對(duì)屬性null的進(jìn)行更新
原因
mybatis-plus FieldStrategy 有三種策略:
IGNORED:忽略NOT_NULL:非 NULL,默認(rèn)策略NOT_EMPTY:非空
默認(rèn)非空,所有更新時(shí)不生效的問題
解決方法
①設(shè)置全局的field-strategy

這樣全局配置會(huì)把所有的屬性都忽略,對(duì)于一些不需要改的屬性可能會(huì)影響業(yè)務(wù)的準(zhǔn)確性。
②給單獨(dú)的屬性設(shè)置field-strategy
根據(jù)實(shí)際應(yīng)用情況對(duì)某些屬性增加該注解來忽略策略
@TableField(strategy=FieldStrategy.IGNORED)

這樣增加該注解的屬性就可以使用updateById()方法進(jìn)行更新null值。
------當(dāng)然還有其他的好的方法也可以去參考
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- mybatis-plus 關(guān)于savebatch,saveorupdatebatch遇到的坑及解決辦法
- Mybatis-Plus使用saveOrUpdate及問題解決方法
- mybatis-plus中l(wèi)ambdaQuery()與lambdaUpdate()比較常見的使用方法總結(jié)
- Mybatis-Plus中updateById方法不能更新空值問題解決
- Mybatis-Plus中update()和updateById()將字段更新為null
- Mybatis-Plus使用updateById()、update()將字段更新為null
- MyBatis update標(biāo)簽詳解
相關(guān)文章
Java使用定時(shí)器編寫一個(gè)簡(jiǎn)單的搶紅包小游戲
這篇文章主要為大家介紹了Java如何使用定時(shí)器編寫一個(gè)簡(jiǎn)單的搶紅包小游戲,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以嘗試一下2022-07-07
Spring加載屬性文件方式(自動(dòng)加載優(yōu)先級(jí)問題)
這篇文章主要介紹了Spring加載屬性文件方式(自動(dòng)加載優(yōu)先級(jí)問題),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02
Java實(shí)現(xiàn)的基于socket通信的實(shí)例代碼
Java實(shí)現(xiàn)的基于socket通信的實(shí)例代碼,需要的朋友可以參考一下2013-03-03
HashMap工作原理_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了HashMap工作原理_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理,需要的朋友可以參考下2017-04-04

