mybatis使用foreach查询不出结果也不报错的问题

网友投稿 296 2022-08-18


mybatis使用foreach查询不出结果也不报错的问题

目录foreach查询不出结果也不报错问题执行结果正确执行结果正确做法使用foreach、in操作注意点错误sql示例改正后的sql为

foreach查询不出结果也不报错问题

首先,执行的时候语法没有报错,其次sql语句拿到数据库去执行能查到数据,但是在接口这边返回空输数据,查看控制台发现sql语句执行了,但是返回结果为0。此时猜想是传入参数的问题。

执行结果

此时数组是直接从参数里接收

仔细看此时的数组和普通的数组还是有差别的

但是此时执行是没有问题的,但是查不到数据

正确执行结果

此时的数组

遍历输出

所以,由此可以看出是参数的问题

正确做法

由于接收到的数组是json数组,不能直接使用,要转成普通数组即可

前端传入参数(数组即可)

使用foreach、in操作注意点

mybatis语法掌握不熟,在写foreach操作时,造成in ()错误,这种情况不符合SQL的语法,导致程序报错。

如果简单只做非空判断,这样也有可能会有问题:本来in一个空列表,应该是没有数据才对,却变成了获取全部数据!

错误sql示例

select count(1) from (

SELECT

distinct a.*

FROM

active AS a

LEFT JOIN active_promotion AS ap ON ap.active_id = a.id

LEFT JOIN promotion_product AS pp ON pp.promotion_id = ap.promotion_id

LEFT JOIN active_area AS aa ON aa.active_id = a.id and aa.status = 1 and aa.area_type = 0

zLoAPQigMqWHERE a.status <![CDATA[!= ]]> 0

AND a.id = #{id}

AND a.name LIKE CONCAT('%',#{name},'%')

AND pp.sku = #{sku}

and aa.area_id IN

#{item}

order by a.create_time desc ) as b

改正后的sql为

select count(1) from (

SELECT

distinct a.*

FROM

active AS a

LEFT JOIN active_promotion AS ap ON ap.active_id = a.id

LEFT JOIN promotion_product AS pp ON pp.promotion_id = ap.promotion_id

LEFT JOIN active_area AS aa ON aa.active_id = a.id and aa.status = 1 and aa.area_type = 0

WHERE a.status <![CDATA[!= ]]> 0

AND a.id = #{id}

AND a.name LIKE CONCAT('%',#{name},'%')

AND pp.sku = #{sku}

and aa.area_id IN

#{item}

and 1=0

order by a.create_time desc ) as b


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:基于Java实现Redis多级缓存方案
下一篇:Java由浅入深带你了解什么是包package
相关文章

 发表评论

暂时没有评论,来抢沙发吧~