https://www.inflearn.com/course/스프링-db-1
1. JDBC 이해
JDBC 이해
- JDBC는 자바에서 데이터베이스에 접속할 수 있도록 하는 자바 API 이다.
- 표준 인터페이스로 3가지를 정의함 ( java.sql.Connection, java.sql.Statement, java.sql.ResultSet )
- JDBC 인터페이스를 각각의 DB 벤더 (회사) 에서 자신의 DB에 맞도록 구현해서 라이브러리로 제공 : JDBC 드라이버
- 데이터 베이스를 다른 종류의 데이터베이스로 변경하면 애플리케이션 서버의 데이터 베이스 사용 코드도 함께 변경해야 하는 문제 해결
- 개발자가 각각의 데이터베이스 마다 커넥션 연결, SQL 전달, 그리고 그 결과를 응답 받는 방법을 새로 학습해야 하는 문제 해결
- ANSI SQL 이라는 표준이 있기는 하지만 일반적인 부분만 공통화하여 한계가 있음
즉, 페이징 SQL은 각각의 데이터베이스마다 사용법이 다름
JDBC와 최신 데이터 접근 기술
- JDBC를 직접 사용하기 보다는 JDBC를 편리하게 사용하는 다양한 기술 존재 (SQL Mapper, ORM 기술)
- SQL Mapper
- 장점 : JDBC를 편리하게 사용하도록 도와준다.
> JDBC 반복 코드 제거, SQL 응답 결과를 객체로 편리하게 변환해줌
- 단점 : 개발자가 SQL을 직접 작성해야한다.
- 대표기술 : 스프링 jdbcTemplate, MyBatis - ORM 기술
- ORM은 객체를 관계형 데이터베이스 테이블과 매핑해주는 기술
- 대표기술 : JPA, 하이버네이트, 이클립스 링크
- JPA는 자바 진영의 ORM 표준 인터페이스, 이것을 구현한것으로 하이버네이트, 이클립스 링크 등 - SQL Mapper는 SQL만 작성할 줄 알면 금방 배워서 사용 가능
ORM은 러닝커브 문제가 있음
JDBC 개발 - 조회 , 수정, 삭제
- @Data lombok 어노테이션에 @equalsandHashcode 와 @Tostring이 포함되어 있다.
- preparestatement와 statement 차이 : 보안, 캐싱 등
- ResultSet은 내부에 있는 커서 ('cursor')를 이동해서 다음 데이터를 조회할 수 있다.
2. 커넥션풀과 데이터소스 이해
커넥션 풀 이해
- 데이터베이스 커넥션을 획득할 때 다음과 같은 복잡한 과정을 거친다.
1. 애플리케이션 로직은 DB 드라이버를 통해 커넥션을 조회한다.
2. DB 드라이버 DB와 TCP/IP 커넥션을 연결한다.
3. DB 드라이버는 TCP/IP 커넥션이 연결되면 ID, PW와 기타 부가정보를 DB에 전달한다.
4. DB는 ID, PW를 통해 내부 인증을 완료하고, 내부에 DB 세션을 생성한다.5. DB는 커넥션 생성이 완료되었다는 응답을 보낸다.
6. DB 드라이버는 커넥션 객체를 생성해서 클라이언트에 반환한다.
- 이러한 복잡한 과정을 거치는것 보다는 커넥션을 미리 생성해두고 사용하는게 커넥션 풀이다.
- 커넥션 풀을 통해 이미 생성되어 있는 커넥션을 객체 참조로 그냥 가져다 쓰기만 하면 됨
DataSource 이해
- 커넥션을 획득하는 다양한 방법 : DriverManager, DBCP2 커넥션 풀, HikariCP 커넥션 풀
- 커넥션을 획득하는 방법을 추상화하였다.
- javax.sql.DataSource 라는 인터페이스를 제공
- 이 인터페이스의 핵심 기능은 커넥션 조회 하나이다. (Connection getConnection() ) - 대부분의 커넥션 풀은 DataSource 인터페이스를 이미 구현해두었다.
- DriverManager는 DataSource 인터페이스를 사용하지 않는다. 따라서 DriverManager 를 사용하다가 DataSource 기반의 커넥션 풀을 사용하도록 변경하면 관련 코드를 다 고쳐야한다. 이를 해결하기 위해 스프링은 DriverManagerDataSource라는 DataSource를 구현한 클래스를 제공한다.
DriverSource 예제1 - DriverManager, DataSource 예제2 - 커넥션 풀, DataSource 적용
- 설정과 사용의 분리가 큰 차이를 만든다.
- 사용하는 곳에서 설정하는 값의 속성에 의존하지 않아도 된다.
- 왜 별도의 쓰레드를 사용해서 커넥션 풀에 커넥션을 채우는걸까?
- 커넥션 풀에 커넥션을 채우는 것은 상대적으로 오래 걸리는 일이다. - 커넥션 풀을 채우기전에 커넥션을 사용하면?
- 내부적으로 기다리게 된다. (대기시간) - 커넥션 풀 맥시멈 수를 넘어서 커넥션을 사용하게 되면?
- lock이 걸림
'Spring' 카테고리의 다른 글
[Spring] 스프링 DB 1편 - 데이터 접근 핵심 원리 - 3 (1) | 2022.10.01 |
---|---|
[Spring] 스프링 DB 1편 - 데이터 접근 핵심 원리 - 2 (0) | 2022.09.18 |
[Spring] ThymeLeaf 정리 - 1 (0) | 2021.11.22 |
[Spring] 실전! Querydsl - 3 (0) | 2021.09.13 |
[Spring] 실전! Querydsl - 2 (0) | 2021.09.09 |