MyBatis更新時新值為null時,updateById()更新失敗問題
MyBatis更新時新值為null時,更新失敗
比如,類Rule中有個字段名為String note,備注是可以為空的。
note不為空時
- 更新方法是,只輸入要更新的值
- 可以構(gòu)造或者不構(gòu)造實體對象
UpdateWrapper<User> updateWrapper = new UpdateWrapper<>(); updateWrapper.eq("name","rule1").set("note", "cannot ignore"); userMapper.update(null, updateWrapper);
note為空時
可行操作:
updateWrapper()方法,把可能為空的字段,如notes,手動設(shè)置。
- 而對于一次更新,所有字段都有可能被更新的情況,這次我是用了反射,設(shè)置了所有可能被更新的字段
- 因為updateWrapper的方法,會默認(rèn)忽略未被set的方法
手動寫一個sql,在xml文件里。也可以繞開NOT NULL的校驗
不可行操作:
- updateById()方法,會默認(rèn)忽略 為null的note字段
- 有考慮過修改更新策略(默認(rèn)配置為“非NULL判斷”,需要改成“忽略判斷”:
全局更新配置:
單個字段的配置:字段加注解
主要想說放棄修改配置的原因:
平時我都是用updateById(),很少用到updateWrapper的。
所以一開始覺得,修改策略是一勞永逸。
但其實,如果改了配置之后,原本項目里使用updateWrapper方法進(jìn)行更新的部分就會受到影響:正常來說,會忽略更新為null的字段;
修改配置后,就不會忽略了為null的字段,這樣會把原來的值誤覆蓋。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用maven的profile構(gòu)建不同環(huán)境配置的方法
這篇文章主要介紹了使用maven的profile構(gòu)建不同環(huán)境配置的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01SpringMVC+Spring+Mybatis實現(xiàn)支付寶支付功能的示例代碼
這篇文章主要介紹了SpringMVC+Spring+Mybatis實現(xiàn)支付寶支付功能的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05Spring Cloud Gateway重試機(jī)制原理解析
這篇文章主要介紹了Spring Cloud Gateway重試機(jī)制原理解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08springMVC之HandlerExceptionResolver使用
這篇文章主要介紹了springMVC之HandlerExceptionResolver使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11詳解mybatis.generator配上最新的mysql 8.0.11的一些坑
這篇文章主要介紹了詳解mybatis.generator配上最新的mysql 8.0.11的一些坑,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10使用spring oauth2框架獲取當(dāng)前登錄用戶信息的實現(xiàn)代碼
這篇文章主要介紹了使用spring oauth2框架獲取當(dāng)前登錄用戶信息的實現(xiàn)代碼,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07Java?超詳細(xì)講解Spring?MVC異常處理機(jī)制
Spring?MVC中提供了一個通用的異常處理機(jī)制,它提供了一個成熟、簡潔并且清晰的異常處理方案。當(dāng)使用Spring?MVC開發(fā)Web應(yīng)用時,利用這套現(xiàn)成的機(jī)制進(jìn)行異常處理也更加自然并且高效2022-04-04