FieldStrategy 會(huì)對(duì) update 和 insert 造成影響,但對(duì)查詢也造成影響的設(shè)計(jì)不合理
執(zhí)行 baseMapper.updateById 方法時(shí),如果想要允許某個(gè)字段被 set 為 null,則須設(shè)置該字段的?FieldStrategy 為?IGNORED,但這也產(chǎn)生了副作用,那就是通過(guò)實(shí)體類構(gòu)造的?QueryWrapper 產(chǎn)出的 sql 的 where 子句帶上了該字段為 null 的查詢條件。
User 對(duì)象中的一個(gè)字段:
@TableField(strategy?=?FieldStrategy.IGNORED) private?String?avatar;
然后查詢:
userMapper.selectList(new?QueryWrapper<>(user));
此時(shí)的 sql 語(yǔ)句將會(huì)像這樣:
select * from user where avatar = null;
這個(gè)似乎無(wú)解?不知道是不是 mybatis-plus 本身在這里的設(shè)計(jì)不合理?
2019-06-23
你好!
? ? ? ?你說(shuō)的問(wèn)題, Mybatis-Plus的作者也意識(shí)到了,所以在即將發(fā)布的3.1.2版本中,對(duì)這里進(jìn)行了調(diào)整。在3.1.2中,全局配置中將新增三個(gè)配置:
? ? ? 1、insertStrategy,在insert 的時(shí)候的字段驗(yàn)證策略;
? ? ? 2、updateStrategy,在 update 的時(shí)候的字段驗(yàn)證策略;
? ? ? 3、selectStrategy,在 select 的時(shí)候的字段驗(yàn)證策略。
? ? ?在即將發(fā)布的新版本中,通過(guò)這幾個(gè)配置,就能解決你提到的這個(gè)問(wèn)題。