欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis Plus 字段為空值時(shí)執(zhí)行更新方法未更新解決方案

 更新時(shí)間:2020年09月02日 15:36:51   作者:qianlingo  
這篇文章主要介紹了Mybatis Plus 字段為空值時(shí)執(zhí)行更新方法未更新解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

問題描述

系統(tǒng)測(cè)試過程中,同事測(cè)試出使用Mybatis Plus提供的封裝方法UpdateById()時(shí),字段從前臺(tái)傳入的數(shù)據(jù)為空值,但是執(zhí)行方法后該字段未得到更新。

問題重現(xiàn)

因涉及到公司層面的模型、數(shù)據(jù),本文都為測(cè)試模型和例子。

實(shí)體類:

@Data
@TableName("shop_item")
public class ShopItem implements Serializable {

  private static final long serialVersionUID = 1L;

 /**
  * 編號(hào)
  */
 @TableId(type= IdType.INPUT)
 private String id;

 /**
  * 物品名稱
  */
 private String itemName;

 /**
  * 物品價(jià)格
  */
 private Double itemPrice;

 /**
 * 添加人編號(hào)
 */
 private String addUserId;

 /**
 * 添加時(shí)間
 */
 private Date addTime;

}

前端提交的JSON數(shù)據(jù):

<script>

var submitData = {
 "id":"361E8C48-6699-4ED5-83C4-7C9D98747C2C",
 "itemName":"iPhone 8 Plus"
 "itemPrice":""
};

</script>

Service 實(shí)現(xiàn)類 更新方法:

@Service
@Slf4j
public class ShopItemServiceImpl extends ServiceImpl<ShopItemMapper, ShopItem> implements IShopItemService {

 @Override
 public ResultVO updateShopItemData(ShopItem shopItem) {
  try {
   this.baseMapper.updateById(shopItem);
  } catch (Exception e) {
   log.error("修改商品數(shù)據(jù)時(shí)異常:{}",e.getMessage());
   return ResultVO.builder().success(false).build();
  }
  return ResultVO.builder().success(true).build();
 }

}

在執(zhí)行 updateShopItemData()方法時(shí),通過Mybatis Log插件控制臺(tái)可以看見日志如下:

update 
 shop_item 
set 
 item_name = 'iPhone 8 Plus' 
where 
id = '361E8C48-6699-4ED5-83C4-7C9D98747C2C';

發(fā)現(xiàn)itemPrice字段未加入SQL語句的set關(guān)鍵字后!Σ(⊙▽⊙"a

沉思了幾分鐘,想起以前使用原生Mybatis生成的Update方法,是有對(duì)值是否為空的判斷,如果為空就不加入到update table set語句內(nèi),于是將問題重心移到Mybatis Plus文檔內(nèi),看看是不是會(huì)有類似于@TableField、@TableId這樣的注解,能解決該問題呢?

解決方案

先放鏈接:點(diǎn)我進(jìn)入官方文檔@TableField

查閱文檔的思路是,我們項(xiàng)目?jī)?nèi)的這個(gè)列是字段,而非主鍵,所以首先排除@TableId注解,直接進(jìn)入@TableField注解的相關(guān)內(nèi)容。

在該注解的屬性描述內(nèi),有這樣一個(gè)字段——“fill”,字段自動(dòng)填充策略。

fill Enum FieldFill.DEFAULT 字段自動(dòng)填充策略

他決定了在執(zhí)行新增或修改方法時(shí),有這個(gè)注解的字段需要怎樣將數(shù)據(jù)進(jìn)行填充,F(xiàn)ieldFill的相關(guān)的屬性,官方描述如下:

描述
DEFAULT 默認(rèn)不處理
INSERT 插入時(shí)填充字段
UPDATE 更新時(shí)填充字段
INSERT_UPDATE 插入和更新時(shí)填充字段

默認(rèn)值是DEFAULT,默認(rèn)不處理,即上文出現(xiàn)的問題——新增、修改該字段為空時(shí),將不自動(dòng)填充即不列入語句,如:

insert into shop_item(shop_price) values(xxxx);

update shop_item set shop_price = xxxx;

OK,解決方案找到了,讓我們來修改實(shí)體類吧!

@Data
@TableName("shop_item")
public class ShopItem implements Serializable {


  private static final long serialVersionUID = 1L;

 /**
  * 編號(hào)
  */
 @TableId(type= IdType.INPUT)
 private String id;

 /**
  * 物品名稱
  */
 private String itemName;

 /**
  * 物品價(jià)格
  */
 @TableField(fill = FieldFill.UPDATE)
 private Double itemPrice;

 /**
 * 添加人編號(hào)
 */
 private String addUserId;

 /**
 * 添加時(shí)間
 */
 private Date addTime;

}

我們?cè)趇temPrice屬性的頂上加上@TableField(fill = FieldFill.UPDATE)后,在執(zhí)行一遍修改方法看看!

update 
 shop_item 
set 
 item_name = 'iPhone 8 Plus',

 item_price = ''
where 
id = '361E8C48-6699-4ED5-83C4-7C9D98747C2C';

bingo,成功!

到此這篇關(guān)于Mybatis Plus 字段為空值時(shí)執(zhí)行更新方法未更新解決方案的文章就介紹到這了,更多相關(guān)Mybatis Plus 字段為空更新內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java實(shí)現(xiàn)解析第三方接口返回的json

    Java實(shí)現(xiàn)解析第三方接口返回的json

    在實(shí)際開發(fā)過程中,免不了和其他公司進(jìn)行聯(lián)調(diào),調(diào)用第三方接口,這個(gè)時(shí)候我們就需要根據(jù)對(duì)方返回的數(shù)據(jù)進(jìn)行解析,獲得我們想要的字段,下面我們就來看看具體有哪些方法吧
    2024-01-01
  • javafx實(shí)現(xiàn)時(shí)鐘效果

    javafx實(shí)現(xiàn)時(shí)鐘效果

    這篇文章主要為大家詳細(xì)介紹了javafx實(shí)現(xiàn)時(shí)鐘效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • Java提示缺少返回語句的解決辦法

    Java提示缺少返回語句的解決辦法

    在本篇文章里小編給大家分享了關(guān)于Java提示缺少返回語句的解決辦法以及相關(guān)知識(shí)點(diǎn),需要的朋友們參考下。
    2019-07-07
  • 強(qiáng)烈推薦IDEA提高開發(fā)效率的必備插件

    強(qiáng)烈推薦IDEA提高開發(fā)效率的必備插件

    這篇文章主要介紹了強(qiáng)烈推薦IDEA提高開發(fā)效率的必備插件,文中有非常詳細(xì)的圖文示例,對(duì)想要提高企業(yè)開發(fā)效率的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • Intellij IDEA官方最完美編程字體Mono使用

    Intellij IDEA官方最完美編程字體Mono使用

    這篇文章主要介紹了Intellij IDEA官方最完美編程字體Mono使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • autoMapping和autoMappingBehavior的區(qū)別及說明

    autoMapping和autoMappingBehavior的區(qū)別及說明

    這篇文章主要介紹了autoMapping和autoMappingBehavior的區(qū)別及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • Java如何將任意類型的Object對(duì)象轉(zhuǎn)換為相應(yīng)的實(shí)體對(duì)象

    Java如何將任意類型的Object對(duì)象轉(zhuǎn)換為相應(yīng)的實(shí)體對(duì)象

    這篇文章主要介紹了Java如何將任意類型的Object對(duì)象轉(zhuǎn)換為相應(yīng)的實(shí)體對(duì)象問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 解析springboot整合谷歌開源緩存框架Guava Cache原理

    解析springboot整合谷歌開源緩存框架Guava Cache原理

    本文主要為大家解析了springboot整合谷歌開源緩存框架Guava Cache的原理以及在實(shí)際開發(fā)過程中的使用,附含源碼,有需要的朋友可以參考下
    2021-08-08
  • java對(duì)象轉(zhuǎn)成byte數(shù)組的3種方法

    java對(duì)象轉(zhuǎn)成byte數(shù)組的3種方法

    這篇文章主要為大家詳細(xì)介紹了java對(duì)象轉(zhuǎn)成byte數(shù)組的3種方法,具有一定的參考價(jià)值,感興趣的朋友可以參考一下
    2018-06-06
  • 如何使用Java讀取PPT文本和圖片

    如何使用Java讀取PPT文本和圖片

    這篇文章主要介紹了如何使用Java讀取PPT文本和圖片,本篇文章將介紹通過Java程序來讀取PPT幻燈片中的文本及圖片的方法。讀取圖片時(shí),可讀取文檔中的所有圖片,也可以讀取指定幻燈片當(dāng)中的圖片,需要的朋友可以參考下
    2019-07-07

最新評(píng)論