JPA
낙관적 LOCK 과 비관적 LOCK - (JPA, Mysql)
낙관적 LOCK 과 비관적 LOCK - (JPA, Mysql)
2022.07.06먼저 알고 가면 좋은 것들 ACID https://hanamon.kr/%EB%8D%B0%EC%9D%B4%ED%84%B0%EB%B2%A0%EC%9D%B4%EC%8A%A4-%ED%8A%B8%EB%9E%9C%EC%9E%AD%EC%85%98%EC%9D%98-acid-%EC%84%B1%EC%A7%88/ [데이터베이스] 트랜잭션의 ACID 성질 - 하나몬 트랜잭션이란 여러 개의 작업을 하나로 묶은 실행 유닛을 말한다. 데이터베이스 트랜잭션은 ACID라는 특성을 가지고 있다. ACID는 데이터베이스 내에서 일어나는 하나의 트랜잭션(transaction)의 안 hanamon.kr Transaction 격리수준 https://zzang9ha.tistory.com/381#:~:text=%ED%8A%B8%EB%9E%9C%E..
JPA - Proxy
JPA - Proxy
2022.07.02Proxy 란 ? porxy 클래스란 실제 클래스를 상속 받아서 만든 실제 클래스와 겉모양이 똑같은 클래스 이다. Client 입장에서는 진짜 객체인지 Proxy 객체인지 구분하지 않고 사용하면 된다는 특징이 있다. Proxy 구조 Proxy 객체는 실제 객체애 대한 참조 (Ref) 를 보관한다. 그리고 Proxy 객체의 메소드를 호출 하면 Prxoy 객체는 실제 Method 를 호출한다. Prxoy 객체 초기화 proxy 객체는 member.getName() 처럼 실제 값에 접근하려고 할때 데이터베이스를 조회해서 실제 엔티티 객체를 생성하는데 이것을 프록시 객체 초기화라 한다. 프록시 객체에 member.getName() 을 호출해서 실제 데이터를 조회한다. 프록시 객체는 실제 엔티티가 생성되어 있지 ..
Connection Pool 이해하고 사용하기
Connection Pool 이해하고 사용하기
2022.06.25connection pool 이란? client 에서 요청이 올때마다 매번 connection 을 맺게 되면 TCP/IP 의 3way handshake 가 발생하게 되고 그만큼 client 에게 응답이 늦어지므로 사용자의 편의성이 하락 할 수 있다. 그리고 Database 의 connection 이 무한하게 증가 함으로 그다지 좋은 방법은 아니라 실무에서는 필수적으로 Connection Pool 을 사용하여 Database 를 사용한다. Spring boot 2.0 의 Connection Pool spring boot 2.0 에서는 connection pool 의 기본을 hikaricp 를 사용하도록 되어 있다. hikaricp 가 궁금하시다면 밑에 링크를 참조하자 GitHub - brettwooldri..
상속 관계 매핑 Entity 를 QueryDsl 에서 사용하기
상속 관계 매핑 Entity 를 QueryDsl 에서 사용하기
2022.05.23Java 에서 말하는 상속 개념이 SQL 에서는 존재하지는 않지만 Jpa 를 사용하여 상속 전략 을 사용하여 두 객체관의 관계를 매핑 하고 상속 관계 전략을 구현한 여러개의 Entity 를 Querydsl 을 사용하여 select 해보겠습니다. https://ict-nroo.tistory.com/128 [JPA] 상속관계 매핑 전략(@Inheritance, @DiscriminatorColumn) 상속관계 매핑 객체는 상속관계가 존재하지만, 관계형 데이터베이스는 상속 관계가 없다.(대부분) 그나마 슈퍼타입 서브타입 관계라는 모델링 기법이 객체 상속과 유사하다. 상속관계 매핑이라 ict-nroo.tistory.com 부모 Entity @Getter @Entity @Inheritance(strategy = S..
JPA 성능 최적화 - N + 1 문제 해결 하기
JPA 성능 최적화 - N + 1 문제 해결 하기
2022.01.30JPA 성능 최적화 JPA 를 사용하면서 병목이 발생하는 구간 의 90% 는 조회에서 발생한다 그도 그럴것이 사실 insert 나 update delete 같은 method 들은 단건에 대해한 것들이 대부분이다. 하지만 select 로 여러 테이블을 join 하여 데이터를 가져올때 시간이 되게 오래 걸리는 경우 가 많다. jpa 에서는 조금 과장을 보태여 이 개념만 잘 알고 있어도 90%는 해결 할 수 있을 것처럼 보인다. 그게 무슨 문제인지 알아보자 회원 이 있고 그 회원은 책을 주문 할 수 있고 배송 정보가 담긴 테이블이 있다고 가정한다. Member.java @Entity @Getter @Setter public class Member { @Id @GeneratedValue @Column(name ..