inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

JDBC 개발 - 등록

close()에 관해 궁금한점이 있습니다.

해결된 질문

701

잘열심히

작성한 질문수 37

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예

[질문 내용]
Connection 객체의 경우에는 해당 커넥션이 만들어지고
close하지않으면 네트워크 리소스 소모때문에 close를 해야하는것으로 이해했습니다.
그렇다면 preparedStatement와 ResultSet객체의 경우에는 해당 데이터베이스로 SQL문을 전송및 전달받는 객체인걸로 보이는데 왜 close로 명시적으로 닫아야하는건가요?

spring mvc spring-jdbc

답변 2

3

김영한

안녕하세요. skkksjslsk님

  1. Connection: Connection 객체는 데이터베이스와의 연결을 나타냅니다. 이 연결은 매우 비용이 많이 드는 자원입니다. 네트워크 리소스와 데이터베이스 서버 자체의 자원을 사용합니다. 따라서 사용이 끝난 후에는 반드시 close() 메소드를 호출하여 자원을 해제해야 합니다. 이는 데이터베이스 연결을 적절하게 관리하는 데 중요합니다.

  2. PreparedStatement: PreparedStatement는 SQL 문을 컴파일하고 데이터베이스에 전송하는 데 사용됩니다. 이 객체도 시스템 자원을 사용하며, 특히 데이터베이스 서버 측에서 메모리와 처리 리소스를 차지합니다. close()를 호출하면 이러한 자원이 해제되어 시스템의 효율성과 성능이 유지됩니다.

  3. ResultSet: ResultSet 객체는 SQL 쿼리의 결과를 담습니다. 이 객체는 결과 데이터에 대한 참조를 유지하며, 때때로 대량의 데이터를 메모리에 로드할 수 있습니다. close()를 호출함으로써 이 데이터에 대한 참조를 해제하고, 연관된 자원을 정리하여 메모리 누수를 방지하고 시스템의 성능을 유지합니다.

     

따라서 해당 자원들을 사용 후 명시적으로 최대한 빠르게 닫아주는 것이 좋습니다.

감사합니다.

4

잘열심히

답변 감사합니다

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

같은 강의에서 비슷한 주제로 질문하신 다른 수강생님의 질문과 그에 대한 강사님의 답변이 도움이 될 것 같습니다. PreparedStatement와 ResultSet 객체를 명시적으로 닫아야 하는 이유와 관련된 내용을 확인하시려면 아래 링크를 참고해 주세요.

  • 질문 제목: “꼭 close()를 해줘야 하나요??”
  • [강의 내용과 관련된 질문인가요? 예/아니오]: 예
  • [인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예/아니오]: 예
  • [질문 잘하기 메뉴얼을 읽어보셨나요? 예/아니오]: 예
  • [질문 내용]: AutoCloseable에 대한 질문과 close()에 대한 필요성에 대해 궁금해하셨습니다.
  • [답변]: PreparedStatement와 ResultSet 역시 자원을 사용하기 때문에 close 해주는 것이 좋으며, AutoCloseable이 있어도 try-with-resources 문법을 사용해야 적용이 됩니다.

꼭 close()를 해줘야 하나요??

이 링크를 통해 자세한 답변을 확인하실 수 있습니다. 감사합니다.

0

잘열심히

제질문은

PreparedStatement과 ResultSet의 어떤 리소스를 사용하길래 close를 진행하는지가 궁금했던것이였습니다.

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

0

31

2

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

0

51

1

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

0

82

1

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

0

68

2

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

0

88

1

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

0

82

2

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

0

58

2

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

0

68

2

after 메서드 사용 유무

0

57

2

데이터베이스 접근 및 DB 락

0

55

1

@SpingBootTest, @TestConfiguration

0

56

1

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

0

48

1

AopCheck Test 부분의 EnhancerBySpring 확인 법??

0

66

2

커리큘럼 관련 질문

0

76

1

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

0

87

1

validation(toMember)의 위치

0

83

2

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

0

165

2

member 상수 질문

0

120

2

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

0

153

2

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

0

109

1

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

0

116

1

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

0

100

1

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

0

98

1

강의 14분쯤 Exception 질문

0

115

2