问题描述 数据库查询结果应该为空, 却返回一个 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, 否则, 会出现意想不到的问题