inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 DB 1편 - 데이터 접근 핵심 원리

PreparedStatement 인터페이스 관련 질문.

402

불타는학구열

작성한 질문수 2

0

정말 기초적인 질문 일 수도 있지만 질문해 봅니다.

JDBC의 이해 MemberRepositoryV0 - 회원 등록 부분에서

public class MemberRepositoryV0 {

public Member save(Member member) throws SQLException {

String sql = "insert into member(member_id, money) values(?, ?)";

Connection con = null;

PreparedStatement pstmt = null;

try {

con = getConnection();

pstmt = con.prepareStatement(sql);

pstmt.setString(1, member.getMemberId());

pstmt.setInt(2, member.getMoney());

pstmt.executeUpdate();

return member;

} catch (SQLException e) {

log.error("db error", e); throw e;

} finally { close(con, pstmt, null);

}

}

위 코드를 보면 PreparedStatement는 아래 사진의 인터페이스로 알고 있습니다.

 

PreparedStatement.JPG

상세 동작이 구현되어 있지 않은 인터페이스 상태인데 위 코드에서 pstmt.executeUpdate();가 동작되는 것에 대해서 동작 원리가 맞는지 궁금합니다.

 

제가 이해한 것으로는 PreparedStatement pstmt 값 -> 사용하는 SQL Driver에서 가져가서 SQL에 맞게 변환 및 적용하는 것으로 이해 했는데 맞나요?

spring

답변 1

0

David

안녕하세요. 불타는학구열님, 공식 서포터즈 David입니다.

PreparedStatement pstmt에 할당되는 구현체는 pstmt = con.prepareStatement(sql);에서 결정됩니다. 따라서, 해당 구문에서 반환된 구현체를 통해 구현된 executeUpdate 메서드가 실행됩니다.

PreparedStatement는 SQL 문을 실행하기 위한 객체를 생성하고 관리하는 책임을 가지고 있습니다.

감사합니다.


spring initialiser 어떤걸 선택해야될지 모르겠어요

0

38

2

트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.

0

51

1

jdbc 학습하다 궁금해서 질문드려요

0

85

1

정상이체와 이체중 예외발생 차이

0

70

2

이번 강의부터가 JDBC 직접 사용 맞나요?

0

89

1

순수한 서비스 계층에 대한 의문???

0

83

2

3_4test, 4test 자동 리소스 안됨

0

60

2

데이터베이스 선택 관련 질문.

0

71

2

after 메서드 사용 유무

0

60

2

데이터베이스 접근 및 DB 락

0

57

1

@SpingBootTest, @TestConfiguration

0

58

1

Read Committed 격리 수준 사용 관련 질문

0

51

1

AopCheck Test 부분의 EnhancerBySpring 확인 법??

0

69

2

커리큘럼 관련 질문

0

78

1

서비서 계층 스프링 프레임워크 사용

0

89

1

validation(toMember)의 위치

0

84

2

데이터 계층에서 서비스 로직의 datasource를 인식하는 방법

0

166

2

member 상수 질문

0

124

2

ctrl + F6 이후로 con 인식이 안 됩니다

0

154

2

DrivenManager 와 Connection 반환에 대한 질문입니다!

0

110

1

섹션5 트랜잭션 템플릿관련 질문(이기종 DB)

0

116

1

세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?

0

103

1

트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?

0

98

1

강의 14분쯤 Exception 질문

0

116

2