首頁 > Java > java教程 > 主體

list All elements are null引起的異常

巴扎黑
發布: 2017-06-26 10:22:04
原創
8075 人瀏覽過

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 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);
            }
        }
登入後複製

 

<span style="font-size: 14px">法二:保证数据库查询出来没有null值,即遇null值转换为默认值<br><br><br></span><span style='font-family: "Microsoft YaHei"'>mysql下使用ifnull/case when均可实现</span><br><span style='font-family: "Microsoft YaHei"'>select  ifnull(min(id),-1) as id,ifnull(min(name),'defaultName') as name from user where 1=2;</span>
登入後複製
(有group by是分组统计,找不到记录就是没有记录)
登入後複製
 <br>
登入後複製
<span style="font-size: 14px"><em><br><br></em></span>
登入後複製

以上是list All elements are null引起的異常的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!