1. 程式人生 > 程式設計 >Mybatis Plus 欄位為空值時執行更新方法未更新解決方案

Mybatis Plus 欄位為空值時執行更新方法未更新解決方案

問題描述

系統測試過程中,同事測試出使用Mybatis Plus提供的封裝方法UpdateById()時,欄位從前臺傳入的資料為空值,但是執行方法後該欄位未得到更新。

問題重現

因涉及到公司層面的模型、資料,本文都為測試模型和例子。

實體類:

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

  private static final long serialVersionUID = 1L;

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

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

 /**
  * 物品價格
  */
 private Double itemPrice;

 /**
 * 新增人編號
 */
 private String addUserId;

 /**
 * 新增時間
 */
 private Date addTime;

}

前端提交的JSON資料:

<script>

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

</script>

Service 實現類 更新方法:

@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("修改商品資料時異常:{}",e.getMessage());
   return ResultVO.builder().success(false).build();
  }
  return ResultVO.builder().success(true).build();
 }

}

在執行 updateShopItemData()方法時,通過Mybatis Log外掛控制檯可以看見日誌如下:

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

發現itemPrice欄位未加入SQL語句的set關鍵字後!Σ(⊙▽⊙"a

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

解決方案

先放連結:點我進入官方文件@TableField

查閱文件的思路是,我們專案內的這個列是欄位,而非主鍵,所以首先排除@TableId註解,直接進入@TableField註解的相關內容。

在該註解的屬性描述內,有這樣一個欄位——“fill”,欄位自動填充策略。

fill Enum FieldFill.DEFAULT 欄位自動填充策略

他決定了在執行新增或修改方法時,有這個註解的欄位需要怎樣將資料進行填充,FieldFill的相關的屬性,官方描述如下:

描述
DEFAULT 預設不處理
INSERT 插入時填充欄位
UPDATE 更新時填充欄位
INSERT_UPDATE 插入和更新時填充欄位

預設值是DEFAULT,預設不處理,即上文出現的問題——新增、修改該欄位為空時,將不自動填充即不列入語句,如:

insert into shop_item(shop_price) values(xxxx);

update shop_item set shop_price = xxxx;

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

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


  private static final long serialVersionUID = 1L;

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

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

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

 /**
 * 新增人編號
 */
 private String addUserId;

 /**
 * 新增時間
 */
 private Date addTime;

}

我們在itemPrice屬性的頂上加上@TableField(fill = FieldFill.UPDATE)後,在執行一遍修改方法看看!

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

bingo,成功!

到此這篇關於Mybatis Plus 欄位為空值時執行更新方法未更新解決方案的文章就介紹到這了,更多相關Mybatis Plus 欄位為空更新內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!