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

被折叠的 条评论
为什么被折叠?



