inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

순수 JDBC

질문이 두개 있습니다

790

terecal

작성한 질문수 162

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 조회 실패");
            }

MVC spring-boot java spring

답변 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 클래스에 넣어주는 과정입니다.

도움이 되셨길 바래요^^

..

0

76

2

Unused property.....

0

99

2

project JDK is misconfigured

0

130

2

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

0

82

2

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

0

91

2

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

0

228

1

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

0

102

2

윈도우 build test오류 질문

1

102

2

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

0

98

2

테스트 실행 시 에러 질문

0

290

1

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

0

77

1

빌드 후 libs 없음

1

128

1

윈도우 gradlew.bat 에러

0

167

1

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

0

88

1

java static class와 kotlin class

0

77

1

스프링 DB연결

0

126

1

소요 시간

0

85

2

ddl.sql에 빨간 밑줄

1

101

2

welcome page 에러

0

180

3

잘 모르겠습니다.

0

163

2

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

0

156

2

index.html Welcome page

0

121

1

프로젝트 gradle-groovy ?

0

365

1

테스트코드 메서드명 한글

0

201

2