listAllelementsarenull引起的异常
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:" + Id() + ",name:" + Name());
}catch (Exception ex){
System.out.println(ex); //java.lang.NullPointerException
}
}
System.out.println("size:"+users.size()); //size:2
nullpointerexception为什么异常
System.out.println("size:"+users.size()); //size:0
//不会进⼊循环
for(User user:users){
try {
System.out.println("id:" + Id() + ",name:" + Name());
}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是分组统计,不到记录就是没有记录),⾄于你想要始终查询出来⼀条
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论