查询结果为空, 却返回All elements are null,spring boot+mybatis

16 篇文章 0 订阅
问题描述 数据库查询结果应该为空, 却返回一个 All elements are null, 如下所示

在这里插入图片描述

1.原代码展示

<select id="rankList" parameterType="com.etouch.pojo.params.FunctionRankParam"
            resultType="com.etouch.pojo.model.FunctionRankModel">
        select
        first_level_page,
        second_level_page,
        function_name,
        menu_name,
        sum(click_count) as clickCount
        from function_rank
        <include refid="baseWhere"/>
        <if test="rankType!=null and rankType == 1 ">
            group by function_name
        </if>
</select>

 <sql id="baseWhere">
        <where>
            1=1
            <if test="timeStart!=null and timeEnd!=null">
                and date_time between #{timeStart} and #{timeEnd}
            </if>
            <if test="rankType!=null">
                and rank_type = #{rankType}
            </if>
        </where>
    </sql>

2. 查询结果展示

这种返回格式, 前端很难处理, debug运行一下接口, 发现, 打印出的日志查询出一条结果, 但是实际上应该是没有的
在这里插入图片描述
下面是打印的sql语句

Preparing: select first_level_page, second_level_page, function_name, menu_name, sum(click_count) as clickCount from function_rank WHERE 1=1 and date_time between ? and ? and rank_type = ? 
Parameters: 2020-06-03(String), 2020-08-03(String), 2(Integer)
     Total: 1

3. 数据库sql测试

将以上sql拿去数据库查询,
在这里插入图片描述
同样是查询出一条空的数据, 分析, 发现, select 后面使用了聚合函数sum, 但是, sql尾部却没有添加group by ,

4. 优化sql

所以 , 这里我们添加上group by试一下
在这里插入图片描述
查询结果显示正确,

5. 继续修改原有代码

    <select id="rankList" parameterType="com.etouch.pojo.params.FunctionRankParam"
            resultType="com.etouch.pojo.model.FunctionRankModel">
        select
        first_level_page,
        second_level_page,
        function_name,
        menu_name,
        sum(click_count) as clickCount
        from function_rank
        <include refid="baseWhere"/>
        <if test="rankType!=null and rankType == 1 ">
            group by function_name
        </if>
        <if test="rankType!=null and rankType == 2 ">
            group by function_name
        </if>
        <if test="rankType!=null and rankType == 3 ">
            group by function_name
        </if>
        <if test="rankType!=null and rankType == 4">
            group by menu_name
        </if>
    </select>

这里我们通知前端人员传递的rankType只可在1到4之间, 也就是会按照function_name或者menu_name分组, 如此一来, 便解决以上问题

6. 测试一下

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
可以看到, 查询结果已经显示正常, 返回的格式也已经正常

7. 总结

平常我们在写sql时, 应该注意如果用到了聚合函数,sum,avg等, 一定要写上group by, 否则, 会出现意想不到的问题

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

意田天

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值