Programming-[Backend] (421) 썸네일형 리스트형 [JPA기본] 13. 객체지향 쿼리 언어 : JPQL-중급문법 1. 경로 표현식 경로 표현식이란 점(.)을 이용하여 객체를 탐색하는 경로를 표현하는 식을 말한다. 경로 표현식으로는 다음 세 가지 경로를 표현할 수 있다. 1 2 3 4 5 select m.username -- 상태 필드 from Member m join m.team t -- 단일 값 연관 필드 join m.orders o -- 컬렉션 값 연관 필드 where t.name = '팀A' cs 상태필드 : 탐색 종료 상태 필드는 어떤 객체의 단순 필드값을 조회하는 것이다. 상태만을 표현하므로 더 이상 경로 표현식을 통해 추가적인 탐색을 할 수 없다. 단일 값 연관 필드 : 탐색 계속, 묵시적 내부 조인 단일값 연관필드는 연관관계를 갖는 필드이므로 추가적인 탐색이 가능하다. 예를 들어 m.team.teamN.. [JPA기본] 12. 객체지향 쿼리 언어 : JPQL-기본문법 1. JPA에서 제공하는 SQL 방식 소개 JPA는 JPQL, JPA Criteria, QueryDSL, 네이티브 SQL, JDBC API 직접 사용 등의 여러 쿼리 방법을 지원한다. JPQL JPQL은 SQL을 추상화한 JPQL이라는 객체 지향 쿼리 언어를 제공한다. 다만 SQL은 DB 테이블을 대상으로 쿼리하는데, JPQL은 엔티티를 대상으로 쿼리한다는 차이가 있다. select * 이 아니라 select m from Member m 이라고 사용하는 점에서도 이를 유추할 수 있다. 그리고 SQL을 추상화했으므로 특정 데이터베이스 vendor에 의존하지 않는다는 장점이 있다. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 tx.begin(); try { Member m.. [JPA기본] 11. 값 타입 1. 값 타입 기본 엔티티 타입과 값 타입의 차이 이제껏 공부해온 엔티티 타입은 식별자(보통 id값)를 통해서 지속적으로 값을 추적할 수 있다. 어떤 엔티티의 특정 필드값이 setter 등으로 변경되면 JPA에서 식별자값을 통해 이를 감지하고 값을 변경해준다. 그러나 값 타입은 변경 시 추적이 불가하다. 그래서 유의해야될 점들이 있는데, 이 글에서는 여러 값 타입들의 종류와 사용법, 유의점에 대해서 알아본다. 사실, 추적이 안되는 값이기 때문에 결론적으로 값 타입을 잘 사용하지 않기에 JPA에서 사용하는 값 타입이라는 것이 있다는 정도만 알아도 될 것 같다. 2. 값 타입의 종류 값 타입은 다음의 3가지가 존재한다. 기본 값 타입 : int, Integer 등 자바 기본 타입이나 객체 임베디드 타입 컬렉.. [링크] ERD 관계선 표기법, 의미 참조 1. https://mjn5027.tistory.com/43 [JPA기본] 10. 즉시/지연 로딩과 CASCADE 1. 즉시/지연 로딩 : FetchType-EAGER, LAZY FetchType.LAZY 특정 엔티티를 불러올때, 연관된 엔티티를 무조건 가져온다면 EAGER, 미리 가져오지 않는다면 LAZY FetchType으로 지정할 수 있다. 아래와 같이 Member 객체에서 연관관계를 갖는 Team 필드의 @ManyToOne에 fetch 속성을 걸어주면 Team 프록시를 초기화하지 않는 이상, Team 테이블에는 쿼리를 보내지 않는다. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 @Entity @Getter @Setter public class Member { @Id @GeneratedValue private Long id; private String name.. [JPA기본] 9. 프록시 객체 1. 프록시 기초 프록시는 JPA의 실제 엔티티를 필요할때만 꺼내쓸 수 있도록 하는 가짜 객체이다. 실제 클래스를 상속받아서 만들어지며 겉모양이 같기 때문에 이론적으로는 사용자가 Proxy 객체를 그대로 써도 문제가 없다. 프록시 객체에는 아래와 같이 상속받은 엔티티 타입의 target이라는 필드값이 있다. 실제 데이터가 필요하면 이 target을 통해 id, name 등 원래 entity의 속성값을 조회한다. 아래 예제를 살펴보자. 아래와 같이 1:N의 관계로 연관지어진 Member와 Team 객체 관계에서 member 객체를 불러와서 SQL문을 확인해보자. src/main/java/com/example/jpamain/JpaMainApplication.java 1 2 3 4 5 6 7 8 9 10 11.. [JPA기본] 8. 연관, 상속관계 매핑 실습 : 테이블 -> 엔티티 환원 1. 테이블 설계도 이때까지 배운 내용을 바탕으로, 테이블 설계 내용에 따라 Entity를 직접 작성해본다. 테이블의 설계도만 보고 이때까지 배운 내용대로 Entity들을 작성할 수 있어야 한다. 실제로 그렇게 해보고, 안되는 부분이 있다면 아래 내용들을 참고한다. 강의에서 나온 테이블 설계도는 다음과 같다. 2. 단방향 연관관계 : ORDERS, MEMBER, DELIVERY Member와 Orders는 1:N의 관계이고, Orders와 Delivery는 1:1의 관계이다. Orders에서 Member를 여러 개 가지므로 Member_id를 FK로 갖는다. 그렇기 때문에 Orders가 연관관계의 주인이다. 단방향 연관관계로 설정된 이유는 (아마도) 비즈니스 로직상 Delivery 정보에서 Order 정.. [TIL][Thymeleaf] String null 처리 : #string.defaultString #strings의 메서드들을 사용하면 객체의 값이 null 일때 처리할 값을 지정할 수 있다. Elvis(?:) 문법을 써도 되지만, 여러 객체가 한 번에 표시될 때는 #strings의 메서드를 활용해야한다. 1 2 3 4 Colored by Color Scripter cs 이렇게 쓰면, 만약 4개의 값 중 세번째 값인 XxxEntity.attr.address.detail 값이 null일때는 , default로 빈 공백(' ')을 넣어준다. 참조 https://cizz3007.github.io/타임리프/syntax/thymeleaf/2018/04/10/thymeleaf2/ 이전 1 ··· 36 37 38 39 40 41 42 ··· 53 다음