問題描述
系統(tǒng)測試過程中,同事測試出使用Mybatis Plus提供的封裝方法UpdateById()時,字段從前臺傳入的數(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; /** * 物品價格 */ private Double itemPrice; /** * 添加人編號 */ private String addUserId; /** * 添加時間 */ 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ù)時異常:{}" ,e.getMessage()); return ResultVO.builder().success( false ).build(); } return ResultVO.builder().success( true ).build(); } } |
在執(zhí)行 updateShopItemData()方法時,通過Mybatis Log插件控制臺可以看見日志如下:
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),看看是不是會有類似于@TableField、@TableId這樣的注解,能解決該問題呢?
解決方案
先放鏈接:點(diǎn)我進(jìn)入官方文檔@TableField
查閱文檔的思路是,我們項(xiàng)目內(nèi)的這個列是字段,而非主鍵,所以首先排除@TableId注解,直接進(jìn)入@TableField注解的相關(guān)內(nèi)容。
在該注解的屬性描述內(nèi),有這樣一個字段——“fill”,字段自動填充策略。
fill | Enum | 否 | FieldFill.DEFAULT | 字段自動填充策略 |
他決定了在執(zhí)行新增或修改方法時,有這個注解的字段需要怎樣將數(shù)據(jù)進(jìn)行填充,F(xiàn)ieldFill的相關(guān)的屬性,官方描述如下:
值 | 描述 |
---|---|
DEFAULT | 默認(rèn)不處理 |
INSERT | 插入時填充字段 |
UPDATE | 更新時填充字段 |
INSERT_UPDATE | 插入和更新時填充字段 |
默認(rèn)值是DEFAULT,默認(rèn)不處理,即上文出現(xiàn)的問題——新增、修改該字段為空時,將不自動填充即不列入語句,如:
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; /** * 物品價格 */ @TableField (fill = FieldFill.UPDATE) private Double itemPrice; /** * 添加人編號 */ private String addUserId; /** * 添加時間 */ 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