mybatis使用foreach查询不出结果也不报错的问题怎么解决(foreach,mybatis,开发技术)

时间:2024-04-30 15:59:11 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

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

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

执行结果

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

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

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

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

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

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

正确执行结果

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

此时的数组

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

遍历输出

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

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

正确做法

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

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

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

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

使用foreach、in操作注意点

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

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

错误sql示例

<selectid="getActiveCount"resultType="int"parameterType="com.missfresh.active.dto.ActiveSearchDTO">selectcount(1)from(SELECTdistincta.*FROMactiveASa<iftest="sku!=''andsku!=null">LEFTJOINactive_promotionASapONap.active_id=a.idLEFTJOINpromotion_productASppONpp.promotion_id=ap.promotion_id</if><iftest="areaIds!=''andareaIds!=null">LEFTJOINactive_areaASaaONaa.active_id=a.idandaa.status=1andaa.area_type=0</if>WHEREa.status<![CDATA[!=]]>0<iftest="id!=0andid!=null">ANDa.id=#{id}</if><iftest="name!=''andname!=null">ANDa.nameLIKECONCAT('%',#{name},'%')</if><iftest="sku!=''andsku!=null">ANDpp.sku=#{sku}</if><!--判断方式错了,应该先用null再用size>0判断;如果areaIds为空,查询结果也应为空,而不是其他查询结果。所以sql有问题--><iftest="areaIds!=''andareaIds!=null">andaa.area_idIN<foreachitem="item"index="index"collection="areaIds"open="("separator=","close=")">#{item}</foreach></if>orderbya.create_timedesc)asb</select>

改正后的sql为

<selectid="getActiveCount"resultType="int"parameterType="com.missfresh.active.dto.ActiveSearchDTO">selectcount(1)from(SELECTdistincta.*FROMactiveASa<iftest="sku!=''andsku!=null">LEFTJOINactive_promotionASapONap.active_id=a.idLEFTJOINpromotion_productASppONpp.promotion_id=ap.promotion_id</if><iftest="areaIds!=''andareaIds!=null">LEFTJOINactive_areaASaaONaa.active_id=a.idandaa.status=1andaa.area_type=0</if>WHEREa.status<![CDATA[!=]]>0<iftest="id!=0andid!=null">ANDa.id=#{id}</if><iftest="name!=''andname!=null">ANDa.nameLIKECONCAT('%',#{name},'%')</if><iftest="sku!=''andsku!=null">ANDpp.sku=#{sku}</if><iftest="areaIds!=nullandareaIds.size>0">andaa.area_idIN<foreachitem="item"index="index"collection="areaIds"open="("separator=","close=")">#{item}</foreach></if><!--加入这个非真条件--><iftest="areaIds==nullorareaIds.size==0">and1=0</if>orderbya.create_timedesc)asb</select>
 </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
本文:mybatis使用foreach查询不出结果也不报错的问题怎么解决的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:如何调用Web API下一篇:

14 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18