> Java > java지도 시간 > 목록으로 인해 발생한 예외 모든 요소가 null입니다.

목록으로 인해 발생한 예외 모든 요소가 null입니다.

巴扎黑
풀어 주다: 2017-06-26 10:22:04
원래의
8169명이 탐색했습니다.

ArrayList를 사용하면 목록의 개체를 변환할 때 java.lang.NullPointerException 예외가 쉽게 발생할 수 있는 null 값을 추가할 수 있습니다.

시나리오:

데이터베이스는 id로 min(id), 1=2인 사용자의 이름으로 min(name)을 선택합니다.

쿼리 결과는 레코드가 없지만 null, null 레코드이므로 The 사용자 객체가 null입니다

List users = useDao.find(xxx); //size=1,모든 요소가 null입니다

이때 사용자 객체를 조작하면 오류가 발생합니다!

Solution

방법 1: 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>
로그인 후 복사

위 내용은 목록으로 인해 발생한 예외 모든 요소가 null입니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿