欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  Java

list All elements are null引起的异常

程序员文章站 2022-04-26 19:44:54
...
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:3for(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); //移除第一个nullSystem.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;
(有group by是分组统计,找不到记录就是没有记录)
 


以上就是list All elements are null引起的异常的详细内容,更多请关注其它相关文章!