一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - Mybatis Plus 字段為空值時(shí)執(zhí)行更新方法未更新解決方案

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

2020-09-03 00:23qianlingo Java教程

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

問題描述

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

問題重現(xiàn)

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

實(shí)體類:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
@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;
 
  /**
   * 物品價(jià)格
   */
  private Double itemPrice;
 
  /**
  *  添加人編號
  */
  private String addUserId;
 
  /**
  *  添加時(shí)間
  */
  private Date addTime;
 
}

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

?
1
2
3
4
5
6
7
8
9
<script>
 
var submitData = {
  "id":"361E8C48-6699-4ED5-83C4-7C9D98747C2C",
  "itemName":"iPhone 8 Plus"
  "itemPrice":""
};
 
</script>

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
@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)可以看見日志如下:

?
1
2
3
4
5
6
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方法,是有對值是否為空的判斷,如果為空就不加入到update table set語句內(nèi),于是將問題重心移到Mybatis Plus文檔內(nèi),看看是不是會(huì)有類似于@TableField、@TableId這樣的注解,能解決該問題呢?

解決方案

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

查閱文檔的思路是,我們項(xiàng)目內(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)填充即不列入語句,如:

?
1
2
3
insert into shop_item(shop_price) values(xxxx);
 
update shop_item set shop_price = xxxx;

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
@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;
 
  /**
   * 物品價(jià)格
   */
  @TableField(fill = FieldFill.UPDATE)
  private Double itemPrice;
 
  /**
  *  添加人編號
  */
  private String addUserId;
 
  /**
  *  添加時(shí)間
  */
  private Date addTime;
 
}

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

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

bingo,成功!

原文鏈接:https://blog.csdn.net/qianlingo/article/details/105120219

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 四虎1515hhcom| 免费观看视频在线 | 欧美国产精品久久 | 日韩欧美精品 | 国产98在线 | 久久青青草视频在线观 | 国产人妖xxxxx免费看 | 色狠狠色狠狠综合天天 | 手机看片自拍自自拍日韩免费 | 日本久久啪啪婷婷激情五月 | 九九精品影院 | 天天做日日做天天添天天欢公交车 | 国产99热 | 青草久久网 | 韩国禁片在线观看久 | 色哟哟久久 | 男gaygays免费网站多人 | 日韩高清一区二区三区不卡 | 青青青手机视频 | 国产成人精品午夜免费 | 国产一区在线免费观看 | 好爽好粗| 国产欧美精品专区一区二区 | 亚洲国产成人精品无码区APP | 国产一级持黄大片99久久 | 亚州男人天堂 | 欧美成人另类人妖 | 国产酒店自拍 | 男男18视频免费网站 | 亚洲久草视频 | 日本sss在线高清观看 | 免费一级特黄特色大片在线观看 | 涩色网| 国产免费专区 | 国产青草视频在线观看免费影院 | 91九色麻豆| 男人的天堂欧美 | 高清一区高清二区视频 | 男人的天堂comwww | 日韩视频免费看 | 日本视频高清免费观看xxx |