본문 바로가기

반응형

전체 글

(65)
[리액티브 코프링] R2DBC 사용법 (연관 관계 구현하기) 이전글 : [리액티브 코프링] R2DBC 사용법 (데이터 저장 & 수정) 모든 예제 코드는 필자의 github 레포지토리 에서 확인할 수 있다. 4. 연관 관계 구현하기 R2DBC는 JPA같은 ORM이 아니므로 연관 관계 매핑을 지원하지 않는다. R2DBC에서 연관 관계 매핑과 같은 기능을 사용하기 위해서는 개발자가 추가적으로 코드를 작성해줘야한다. 도메인 & 요구사항 본 예제에서는 스프링 부트 실전 활용 마스터 의 장바구니 예제를 차용하고 있다. Cart, CartItem, Item 엔티티를 사용하고 있으며 연관 관계는 아래와 같다. Cart와 CartItem은 1대 N 연관관계이고, CartItem과 Item은 일대일 연관관계이다. 엔티티 설정 (Transient) 데이터 조회편에서 엔티티를 선언했지..
[리액티브 코프링] R2DBC 사용법 (데이터 저장 & 수정) 이전글 : [리액티브 코프링] R2DBC 사용법 (데이터 조회) 모든 예제 코드는 필자의 github 레포지토리 에서 확인할 수 있다. 데이터 저장하기 이번 글에서 다루는 데이터를 저장하는 방법은 아래와 같다. 레포지토리의 save() 함수 사용 Fluent API 사용 Native Query 사용 Batch Insert 먼저, 1, 2, 3번에 해당하는 코드를 보도록 하자. 각각의 테스트 코드 위에 주석으로 데이터를 저장하는 방법을 명시했다. @SpringBootTest class ItemSaveTest { @Autowired private lateinit var itemRepository: ItemRepository @Autowired private lateinit var connectionFacto..
[리액티브 코프링] R2DBC 사용법 (데이터 조회) 이전글 : [리액티브 코프링] R2DBC 사용법 (들어가며) 모든 예제 코드는 필자의 github 레포지토리 에서 확인할 수 있다. 2. 엔티티 선언하기 이번 예제에서 사용할 엔티티들을 선언하자. Spring Data R2DBC에서는 연관관계를 지원하지 않는다. 객체간 연관관계를 구성하는 멤버에는 @Transient 어노테이션을 사용해줘야 스프링 실행 시 오류가 나지 않는다. data class Cart( @Id val id: Long? = null, @Transient var cartItems: List = listOf() ) data class CartItem( @Id val id: Long? = null, var quantity: Int = 1, @Column("cart_id") var cartId..
[리액티브 코프링] R2DBC 사용법 (들어가며) [리액티브 코프링] R2DBC 사용법 0. 들어가며 최근 스프링 부트 실전 활용 마스터 라는 책으로 스프링 리액티브 프로그래밍을 학습했다. 리액티브로 동작하는 코드에 블로킹으로 동작하는 코드가 존재한다면 병목이 발생해서 리액티브 프로그래밍의 이점이 없어지기 때문에 책에서는 데이터 스토어로 RDBMS(관계형 데이터베이스)가 아닌 리액티브 패러다임을 지원하는 MongoDB를 사용하고 있다. 여태까지 RDBMS(관계형 데이터베이스)를 비동기로 연결해주는 R2DBC 가 1.0 버전에 도달하지 못한 상태였기 때문이다. 하지만 최근 R2DBC가 1.0 버전을 릴리즈했고 R2DBC 사양을 따르는 개별 데이터베이스 드라이버들도 오래되지 않아 1.0 버전에 도달할 것으로 보인다. 그래서 R2DBC를 이용해 리액티브 코프..
[하이버네이트 유저 가이드 파헤치기] @Where - 5.9 최근 이 연재글에서 @Formula와 @ColumnTransformer에 대해서 다루었다. @Formula 어노테이션을 사용하면 가상 칼럼을 선언해서 애플리케이션단에서 수행할 계산식을 데이터베이스에 위임하거나 카운트 성능을 최적화할 수 있다. @ColumnTransformer는 엔티티를 영속화하거나 불러올 때 특정 칼럼에 대해서 계산식을 적용할 수 있다. 둘 다 JPA를 이용해 개발자가 애플리케이션단에서 수행할 작업을 데이터베이스에 위임할 수 있다는 공통점이 있다. 이번 글에서는 엔티티를 조회할 때 특정 조건을 적용할 수 있는 @Where 어노테이션을 다루겠다. 5.9.1. @Where 당신은 엔티티나 연관 관게에 있는 엔티티 컬렉션을 사용자 정의 SQL 기준을 이용해 걸러내고 싶을 때가 간혹 있을 수 ..
[하이버네이트 유저 가이드 파헤치기] @Formula - 2.3.20 2.3.20. @Formula 때때로, 당신은 JVM보다 데이터베이스가 어떤 계산을 수행하는 것을 원할 때 당신은 가상 칼럼의 일종을 만들 수 있다. 당신은 데이터베이스 칼럼으로 매핑되는 엔티티 속성 대신 SQL 조각(formula라고 불림)을 엔티티 속성으로 사용할 수 있다. 이 속성은 읽기 전용이다. (이 속성의 값은 당신이 선언한 formula fragment에 의해 계산된다.) 당신은 @Formula 어노테이션이 데이터베이스 이식성에 영향을 미치는 native SQL 문을 사용하는 것을 인지해야한다. (필자 해설: JPQL이 아니라 native SQL이기 때문에 RDBMS의 종류를 교체하는 경우 이식성에 안 좋을 수 있다는 의미) 원문 Sometimes, you want the Database t..
[하이버네이트 유저 가이드 파헤치기] Column transformers: read and write expressions - 2.3.19 2.3.19. Column transformers: read and write expressions 하이버네이트는 @Basic 타입에 매핑되는 칼럼의 값을 읽고 쓰는데 사용하는 SQL를 사용자가 정의할 수 있도록 허용한다. 예를 들면, 만일 당신의 데이터베이스가 데이터 암호화 함수 세트를 제공한다면, 당신은 아래 예제와 같이 개별 칼럼에 대해서 암호화 함수 세트를 호출할 수 있다. 원문 Hibernate allows you to customize the SQL it uses to read and write the values of columns mapped to @Basic types. For example, if your database provides a set of data encryption fu..
[하이버네이트 유저 가이드 파헤치기] Generated properties - 2.3.18. 2.3.18. Generated properties 생성된 속성(Generated properties)은 데이터베이스에 의해 생성된 값을 가지는 속성이다. 일반적으로 하이버네이트 애플리케이션은 데이터베이스가 생성하는 속성들을 포함하는 오브젝트를 갱신해야한다. 그러나 해당 속성을 데이터베이스가 생성하는 속성으로 표시하면 하이버네이트가 대신 오브젝트를 갱신한다. 하이버네이트가 생성된 속성(Generated properties)이 정의된 엔티티를 위해 Insert 문이나 Update 문을 발행할 때, 하이버네이트는 즉시 데이터베이스로부터 생성된 값을 탐색하기 위해 select 문을 발행한다. 생성된 속성은 추가적으로 insert와 update를 불가능하도록 설정해야한다. 오직 @Version과 @Basic 타..

반응형