Mybatis Plus 字段為空值時執(zhí)行更新方法未更新解決方案
問題描述
系統(tǒng)測試過程中,同事測試出使用Mybatis Plus提供的封裝方法UpdateById()時,字段從前臺傳入的數(shù)據(jù)為空值,但是執(zhí)行方法后該字段未得到更新。
問題重現(xiàn)
因涉及到公司層面的模型、數(shù)據(jù),本文都為測試模型和例子。
實體類:
@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數(shù)據(jù):
<script>
var submitData = {
"id":"361E8C48-6699-4ED5-83C4-7C9D98747C2C",
"itemName":"iPhone 8 Plus"
"itemPrice":""
};
</script>
Service 實現(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ù)時異常:{}",e.getMessage());
return ResultVO.builder().success(false).build();
}
return ResultVO.builder().success(true).build();
}
}
在執(zhí)行 updateShopItemData()方法時,通過Mybatis Log插件控制臺可以看見日志如下:
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),看看是不是會有類似于@TableField、@TableId這樣的注解,能解決該問題呢?
解決方案
先放鏈接:點我進入官方文檔@TableField
查閱文檔的思路是,我們項目內(nèi)的這個列是字段,而非主鍵,所以首先排除@TableId注解,直接進入@TableField注解的相關(guān)內(nèi)容。
在該注解的屬性描述內(nèi),有這樣一個字段——“fill”,字段自動填充策略。
| fill | Enum | 否 | FieldFill.DEFAULT | 字段自動填充策略 |
他決定了在執(zhí)行新增或修改方法時,有這個注解的字段需要怎樣將數(shù)據(jù)進行填充,F(xiàn)ieldFill的相關(guān)的屬性,官方描述如下:
| 值 | 描述 |
|---|---|
| DEFAULT | 默認不處理 |
| INSERT | 插入時填充字段 |
| UPDATE | 更新時填充字段 |
| INSERT_UPDATE | 插入和更新時填充字段 |
默認值是DEFAULT,默認不處理,即上文出現(xiàn)的問題——新增、修改該字段為空時,將不自動填充即不列入語句,如:
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)后,在執(zhí)行一遍修改方法看看!
update shop_item set item_name = 'iPhone 8 Plus', item_price = '' where id = '361E8C48-6699-4ED5-83C4-7C9D98747C2C';
bingo,成功!
到此這篇關(guān)于Mybatis Plus 字段為空值時執(zhí)行更新方法未更新解決方案的文章就介紹到這了,更多相關(guān)Mybatis Plus 字段為空更新內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot啟動報錯的11個高頻問題排查與解決終極指南
這篇文章主要為大家詳細介紹了SpringBoot啟動報錯的11個高頻問題的排查與解決,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下2025-03-03
關(guān)于SpringBoot整合RabbitMQ實現(xiàn)死信隊列
這篇文章主要介紹了關(guān)于SpringBoot整合RabbitMQ實現(xiàn)死信隊列,死信隊列實際上就是一個普通的隊列,只是這個隊列跟死信交換機進行了綁定,用來存放死信而已,需要的朋友可以參考下2023-05-05
小白必看toString(),String.valueOf,(String)強轉(zhuǎn)
在Java中,往往需要把一個類型的變量轉(zhuǎn)換成String 類型,本文主要介紹了toString(),String.valueOf,(String)強轉(zhuǎn),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-06-06

