Mybatis Plus的Wrapper多出无关条件的原因

文章讨论了在使用MybatisPlusWrappers时遇到的问题,查询条件中出现未设置的type=0,原因是当实体类字段类型为int且无显式赋值时,默认值会被包含在查询中。解决方法是将int类型改为Integer以避免此问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述

mybatis plus 的wrappers在使用的时候,会在查询条件上莫名其妙的多出其他条件,但是我并没有在wrapper里面添加这些条件。

比如这个wrapper:

Wrappers.query(new QuotaEntity()).in("name", szQuotaNames)

执行查询后,sql是:

select * from xxx WHERE type=0 AND name IN (?)

其中,type=0这个条件就是多出来的,在查询构造器里面明明没有指定这个条件。

原因

这个问题的原因在QuotaEntity实体类里面,里面的type字段类型是int,int类型不给值的话默认会是0,这里猜想构造器会默认把实体类对象里面值非空的都加入查询条件。

所以,把int改成Integer就可以了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值