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

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

terecal님의 프로필 이미지
terecal

작성한 질문수

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

순수 JDBC

질문이 두개 있습니다

작성

·

738

0

안녕하세여  강사님
먼저 좋은 강의 감사드리고여
질문이 두개 있습니다 

둘다 save 함수에 관해서인데여 

1.
Statement.RETURN_GENERATED_KEYS 를 리턴 받기 위해 디비 설정이 추가적으로 필요한가요?

ex)
            pstmt = conn.prepareStatement(sql,
                    Statement.RETURN_GENERATED_KEYS);

2.
member.setId(rs.getLong(1)); 를 하는 이유는 무엇인가여?

            if (rs.next()) {
                // 입력 성공시 member 객체의 id 설정 하기
                member.setId(rs.getLong(1));
            } else {
                throw new SQLException("id 조회 실패");
            }

답변 1

0

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. terecal님^^

지금 테이블의 id를 DB가 제공해주는 자동증가를 사용하고 있습니다.

create table member
(
id bigint generated by default as identity,
name varchar(255),
primary key (id)
);

이렇게 되면 id에 값 없이 DB에 member를 insert 해봐야 id가 만들어집니다. id를 DB가 자동생성하기 때문이지요.

그러면 이렇게 DB가 생성한 id 값이 필요하면 DB에서 새로 생성된 id 값을 읽어와야 합니다. 그 기능이 바로 RETURN_GENERATED_KEYS 인 것이지요.

그리고 2번은 DB가 생성해준 값을 읽어서 Member 클래스에 넣어주는 과정입니다.

도움이 되셨길 바래요^^

terecal님의 프로필 이미지
terecal

작성한 질문수

질문하기