中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-09-16 21:25:58 來源:腳本之家 閱讀:388 作者:qianlingo 欄目:開發技術

問題描述

系統測試過程中,同事測試出使用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,成功!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

芮城县| 蕉岭县| 巫山县| 德化县| 麟游县| 故城县| 屏南县| 桑日县| 彭水| 卓尼县| 昌平区| 苏尼特右旗| 邻水| 塔河县| 中阳县| 襄垣县| 松滋市| 沂源县| 宣化县| 平远县| 灵璧县| 洛扎县| 杭州市| 同仁县| 合阳县| 竹山县| 灵台县| 望奎县| 长宁区| 泽普县| 沽源县| 故城县| 金湖县| 沛县| 合川市| 鲁甸县| 油尖旺区| 康乐县| 平江县| 广丰县| 河津市|