亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

FieldStrategy 會對 update 和 insert 造成影響,但對查詢也造成影響的設計不合理

執行 baseMapper.updateById 方法時,如果想要允許某個字段被 set 為 null,則須設置該字段的?FieldStrategy 為?IGNORED,但這也產生了副作用,那就是通過實體類構造的?QueryWrapper 產出的 sql 的 where 子句帶上了該字段為 null 的查詢條件。

User 對象中的一個字段:

@TableField(strategy?=?FieldStrategy.IGNORED)
private?String?avatar;

然后查詢:

userMapper.selectList(new?QueryWrapper<>(user));

此時的 sql 語句將會像這樣:

select * from user where avatar = null;

這個似乎無解?不知道是不是 mybatis-plus 本身在這里的設計不合理?

正在回答

1 回答

你好!

? ? ? ?你說的問題, Mybatis-Plus的作者也意識到了,所以在即將發布的3.1.2版本中,對這里進行了調整。在3.1.2中,全局配置中將新增三個配置:

? ? ? 1、insertStrategy,在insert 的時候的字段驗證策略;

? ? ? 2、updateStrategy,在 update 的時候的字段驗證策略;

? ? ? 3、selectStrategy,在 select 的時候的字段驗證策略。

? ? ?在即將發布的新版本中,通過這幾個配置,就能解決你提到的這個問題。




0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

FieldStrategy 會對 update 和 insert 造成影響,但對查詢也造成影響的設計不合理

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號