질문이 두개 있습니다
790
작성한 질문수 162
안녕하세여 강사님
먼저 좋은 강의 감사드리고여
질문이 두개 있습니다
둘다 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 클래스에 넣어주는 과정입니다.
도움이 되셨길 바래요^^
..
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





