mybatis踩坑小记
数据库查询没有结果,结果为:

<select id="selectOrderIdNotIntegeration" resultType="java.lang.Long">
SELECT
temp.order_id
FROM
t_order_entrust e
LEFT JOIN (SELECT order_id,erp_code FROM t_order_entrust WHERE valid =1 AND order_id IN
<foreach collection="List" open="(" close=")" item="item" separator="," index="index">
#{item.orderId}
</foreach>) temp ON e.erp_code = temp.erp_code
WHERE
e.source != 3 AND e.source != 4
GROUP BY
temp.order_id
</select>
此时Mapper层:
List<Long> selectOrderIdNotIntegeration(@Param("List") List<CreateEntrustStatementInfoListResponseModel> responseList);
这时返回的结果的List会有一个元素为null的结果,size = 1.需要注意排除掉。
解决办法:
https://www.cnblogs.com/hdwang/p/7002086.html
list All elements are null引起的异常
ArrayList允许添加null值,就容易造成了list内的对象转换出现java.lang.NullPointerException异常。
场景:
数据库 select min(id) as id,min(name) as name from user where 1=2;
查询出的不是没有记录,而是一条 null,null这样的记录,导致User对象为null
List<User> users = useDao.find(xxx); //size=1,All elements are null
这时候对user对象操作就会报错!
解决办法
法一:移除null元素
示例:
List<User> users = new ArrayList<User>();
users.add(null);
users.add(null);
users.add(null);
System.out.println("size:"+users.size()); //size:3
for(User user:users){
try {
System.out.println("id:" + user.getId() + ",name:" + user.getName());
}catch (Exception ex){
System.out.println(ex); //java.lang.NullPointerException
}
}
users.remove(null); //移除第一个null
System.out.println("size:"+users.size()); //size:2
users.removeAll(Collections.singleton(null)); //移除所有的null元素
System.out.println("size:"+users.size()); //size:0
//不会进入循环
for(User user:users){
try {
System.out.println("id:" + user.getId() + ",name:" + user.getName());
}catch (Exception ex){
System.out.println(ex);
}
}
法二:保证数据库查询出来没有null值,即遇null值转换为默认值
mysql下使用ifnull/case when均可实现
select ifnull(min(id),-1) as id,ifnull(min(name),'defaultName') as name from user where 1=2;
select case when min(id) is null then -1 else min(id) end as id,case when min(name) is null then 'defaultName' else min(name) end as name from user where 1=2;
这样子查询出来的结果如下 id name -1 defaultName 总结:具体情况依据业务实现,当对数据库查询统计的时候,没有group by关键字而使用聚集函数的时候一定要注意null值情况(有group by是分组统计,找不到记录就是没有记录),至于你想要始终查询出来一条记录且元素有默认值,还是不要显示记录,依据业务而定。两种情况对应两种解决方案。
273

被折叠的 条评论
为什么被折叠?



