inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

순수 JDBC

질문 드립니다 !!

160

찌니

작성한 질문수 3

0

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

spring-boot java spring MVC

답변 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); 와 같은 형태가 될것이라고 예측할 수 있습니다.

.

감사합니다.

인텔리제이 오류

0

51

1

..

0

113

2

Unused property.....

0

121

2

project JDK is misconfigured

0

168

2

외부 API의 ID 타입(String/UUID)과 내부 도메인의 ID 타입(Long)이 불일치할 때의 설계 정석

0

102

2

단위/통합 테스트 버전충돌 문제

0

103

2

❗️springboot 4.0.2 버전 aspectj dependency 설정❗️

0

256

1

왜 컨트롤러는 변한게 없는데 새로 만든 html 파일이 뜨나요?

0

125

2

윈도우 build test오류 질문

1

123

2

테스트 관련 공부에 대한 조언을 얻고 싶습니다

0

113

2

테스트 실행 시 에러 질문

0

320

1

name을 통한 비교와 객체를 통한 비교

0

82

1

빌드 후 libs 없음

1

150

1

윈도우 gradlew.bat 에러

0

187

1

@PostMapping("/members/new")가 동작하지 않습니다

0

98

1

java static class와 kotlin class

0

91

1

스프링 DB연결

0

146

1

소요 시간

0

96

2

ddl.sql에 빨간 밑줄

1

118

2

welcome page 에러

0

201

3

잘 모르겠습니다.

0

173

2

fail을 똑같이 쳤는데 오류가 발생해요

0

174

2

index.html Welcome page

0

137

1

프로젝트 gradle-groovy ?

0

403

1