mybatis使用foreach查询不出结果也不报错的问题
(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun)
foreach查询不出结果也不报错问题
首先,执行的时候语法没有报错,其次sql语句拿到数据库去执行能查到数据,但是在接口这边返回空输数据,查看控制台发现sql语句执行了,但是返回结果为0。此时猜想是传入参数的问题。
执行结果
此时数组是直接从参数里接收
仔细看此时的数组和普通的数组还是有差别的
但是此时执行是没有问题的,但是查不到数据
正确执行结果
此时的数组
遍历输出
所以,由此可以看出是参数的问题
正确做法
由于接收到的数组是json数组,不能直接使用,要转成普通数组即可
前端传入参数(数组即可)
使用foreach、in操作注意点
mybatis语法掌握不熟,在写foreach操作时,造成in ()错误,这种情况不符合SQL的语法,导致程序报错。
如果简单只做非空判断,这样也有可能会有问题:本来in一个空列表,应该是没有数据才对,却变成了获取全部数据!
错误sql示例
<select id="getActiveCount" resultType="int" parameterType="com.missfresh.active.dto.ActiveSearchDTO"> ? ? ? ? select count(1) from ( ? ? ? ? SELECT ? ? ? ? distinct ?a.* ? ? ? ? FROM ? ? ? ? active AS a ? ? ? ? <if test="sku!='' and sku!=null"> ? ? ? ? ? ? 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 ? ? ? ? </if> ? ? ? ? <if test="areaIds!='' and areaIds!=null"> ? ? ? ? ? ? LEFT JOIN active_area AS aa ON aa.active_id = a.id and aa.status = 1 and aa.area_type = 0 ? ? ? ? </if> ? ? ? ? WHERE a.status <![CDATA[!= ]]> 0 ? ? ? ? <if test="id!=0 and id!=null"> ? ? ? ? ? ? AND a.id = #{id} ? ? ? ? </if> ? ? ? ? <if test="name!='' and name!=null"> ? ? ? ? ? ? AND a.name LIKE CONCAT('%',#{name},'%') ? ? ? ? </if> ? ? ? ? <if test="sku!='' and sku!=null"> ? ? ? ? ? ? AND pp.sku = #{sku} ? ? ? ? </if> ? ? ? ? <!--判断方式错了,应该先用null再用size>0判断;如果areaIds为空,查询结果也应为空,而不是其他查询结果。所以sql有问题--> ? ? ? ? <if test="areaIds!='' and areaIds!=null"> ? ? ? ? ? ? and aa.area_id IN ? ? ? ? ? ? <foreach item="item" index="index" collection="areaIds" open="(" separator="," close=")"> ? ? ? ? ? ? ? ? #{item} ? ? ? ? ? ? </foreach> ? ? ? ? </if> ? ? ? ? order by a.create_time desc ) as b ? ? </select>
改正后的sql为
<select id="getActiveCount" resultType="int" parameterType="com.missfresh.active.dto.ActiveSearchDTO"> ? ? ? ? select count(1) from ( ? ? ? ? SELECT ? ? ? ? distinct ?a.* ? ? ? ? FROM ? ? ? ? active AS a ? ? ? ? <if test="sku!='' and sku!=null"> ? ? ? ? ? ? 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 ? ? ? ? </if> ? ? ? ? <if test="areaIds!='' and areaIds!=null"> ? ? ? ? ? ? LEFT JOIN active_area AS aa ON aa.active_id = a.id and aa.status = 1 and aa.area_type = 0 ? ? ? ? </if> ? ? ? ? WHERE a.status <![CDATA[!= ]]> 0 ? ? ? ? <if test="id!=0 and id!=null"> ? ? ? ? ? ? AND a.id = #{id} ? ? ? ? </if> ? ? ? ? <if test="name!='' and name!=null"> ? ? ? ? ? ? AND a.name LIKE CONCAT('%',#{name},'%') ? ? ? ? </if> ? ? ? ? <if test="sku!='' and sku!=null"> ? ? ? ? ? ? AND pp.sku = #{sku} ? ? ? ? </if> ? ? ? ? <if test="areaIds!=null and areaIds.size > 0"> ? ? ? ? ? ? and aa.area_id IN ? ? ? ? ? ? <foreach item="item" index="index" collection="areaIds" open="(" separator="," close=")"> ? ? ? ? ? ? ? ? #{item} ? ? ? ? ? ? </foreach> ? ? ? ? </if> ? ? ? ? <!--加入这个非真条件--> ? ? ? ? <if test="areaIds==null or areaIds.size == ?0"> ? ? ? ? and 1=0 ? ? ? ? </if> ? ? ? ? order by a.create_time desc ) as b ? ? </select>
以上为个人经验,希望能给大家一个参考,也希望大家多多支持程序员之家。
相关文章
Spring?Boot与Spring?MVC?Spring对比及核心概念
这篇文章主要为大家介绍了Spring?Boot与Spring?MVC?Spring的对比以及你需要了解的核心概念,有需要的朋友可以借鉴参考下,希望能够有所帮助2022-03-03
最新评论