인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

찌니님의 프로필 이미지
찌니

작성한 질문수

스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술

순수 JDBC

질문 드립니다 !!

작성

·

139

0

김영한님 안녕하세요 !!
강의 정말 잘 듣고 있습니다 !!
순수 JDBC 강의 중에 회원등록하는 인터페이스를 구현할 때(JdbcMemberRepository.java)
rs = pstmt.getGenerateKeys(); 로 키를 받아온다음
rs.next()가 존재하면 member.setId(rs.getLong(1)); 이라고 코드를 작성하셨는데 이 1의 의미를 정확히 모르겠습니다.
인텔리제이에는 columnIndex 라고 의미가 나오는데 rs가 어떤 결과값이 나와서 columnIndex 값을 1로 넣으신건지, 그리고 왜 인덱스가 0이 아닌 1로 넣어야 하는건지 궁금합니다 !

답변 1

0

안녕하세요. 찌니 님, 공식 서포터즈 codesweaver 입니다.
.

columnindex 의 이미는 어떤 테이블을 조회했을때 결과의 행(세로) 번호를 지정하는 것입니다. 자바에서는 이러한 인덱스가 0으로 시작하는 것이 일반적이긴 하나 ResultSet은 1번인덱스의 첫번째 행을 지정하도록 작성되어있기에 1부터 시작합니다. :)

.

만약 member 테이블을 조회해서 결과값이 아래와 같을 때.

id | name | age

----------------

1 | codesweaver | 30

rs.getLong(1); 이라는 코드는 다음과 같은 의미가 됩니다. '첫번째 행(id)의 값을 가져오는데, 그 값을 Long (큰 정수) 타입이야.' 라는 의미입니다. 만약 rs.getLong(2); 라고 코드를 작성하면 어떻게 될까요? codesweaver는 Long으로 읽을 수 없기에 오류가 발생합니다. 이름 항목을 꺼내려면 rs.getString(2); 와 같은 형태가 될것이라고 예측할 수 있습니다.

.

감사합니다.

찌니님의 프로필 이미지
찌니

작성한 질문수

질문하기