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

作者:HYDMonster 时间:2023-11-24 22:36:17 

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示例

<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>

来源:https://blog.csdn.net/HYDMonster/article/details/87909731

标签:mybatis,foreach,查询结果
0
投稿

猜你喜欢

  • C#使用System.Net邮件发送功能踩过的坑

    2022-09-09 18:16:11
  • C#实现扫雷游戏

    2023-12-10 07:51:05
  • AndroidStudio实现能在图片上涂鸦程序

    2023-09-14 06:57:02
  • JavaFx 实现按钮防抖功能

    2023-03-20 07:34:48
  • Android仿Flipboard动画效果的实现代码

    2022-07-29 13:52:02
  • Android EasyPlayer声音自动停止、恢复,一键静音等功能

    2023-01-12 21:16:48
  • 基于C#实现Windows服务状态启动和停止服务的方法

    2022-07-27 12:17:57
  • java安全编码指南之:表达式规则说明

    2021-06-01 17:48:44
  • Android使用系统相机进行拍照的步骤

    2023-10-07 16:05:05
  • Android高仿微信聊天界面代码分享

    2023-01-23 12:03:03
  • springboot配置项目启动后自动打开浏览器访问项目方式

    2023-10-05 07:33:09
  • Spring-boot JMS 发送消息慢的解决方法

    2023-02-06 07:50:54
  • LINQ基础之Intersect、Except和Distinct子句

    2022-01-19 00:46:13
  • C语言中下标与指针的转换以及指向指针的指针的例子

    2023-05-15 23:46:49
  • sublime text3搭建配置c语言编译环境的详细图解教程(小白级)

    2021-12-16 09:18:27
  • android 实现在照片上绘制涂鸦的方法

    2023-09-17 13:24:49
  • Android 重力传感器在游戏开发中的应用

    2021-11-27 05:54:09
  • Java实现导出word表格的示例详解

    2023-01-02 21:36:48
  • Spring和SpringBoot之间的区别

    2022-09-28 11:47:38
  • C#利用递归算法解决汉诺塔问题

    2022-04-29 23:04:10
  • asp之家 软件编程 m.aspxhome.com