# 경로 표현식

경로 표현식\
.(점)을 찍어 객체 그래프를 탐색하는 것

```sql
select m.username -> 상태 필드
    from Member m
    join m.team t -> 단일 값 연관 필드
    join m.orders o -> 컬렉션 값 연관 필드
where t.name = '팀A'
```

꼭 구분하기!

1. 상태 필드(state field): 단순히 값을 저장하기 위한 필드 (ex: m.username)
2. 연관관계를 위한 필드\
   **단일 값 연관 필드 : 대상이 엔티티**(ex: m.team). @ManyToOne, @OneToOne\
   **컬렉션 값 연관 필드 : 대상이 컬렉션**(ex: m.orders) @OneToMany, @ManyToMany

경로 표현식 특징

* 상태 필드(state field): 경로 탐색의 끝, 탐색X
* 단일 값 연관 경로: 묵시적 내부 조인(inner join) 발생, 탐색O
* 컬렉션 값 연관 경로: 묵시적 내부 조인 발생, **탐색X**

  **FROM 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통해 탐색 가능**

명시적 조인, 묵시적 조인

* 명시적 조인: join 키워드 직접 사용

```sql
select m from Member m join m.team t
```

* 묵시적 조인 : 경로 표현식에 의해 묵시적으로 SQL 조인 발생. 내부 조인만 가능\
  외부 조인 불가능=>명시적 조인(left join)으로 해야함

```sql
select m.team from Member m
```

경로 표현식 - 예제

```sql
select o.member.team 
from Order o 
```

```sql
select t.membes from Team 
```

컬렉션을 명시적 조인으로 가져온 다음 별칭 m을 가져와서 username으로 했기 때문에 m으로 다시 시작한다. 그래서 성공.

```sql
select m.username from Team t join t.members m 
```

실패 : 컬렉션은 컬렉션 그 자체로 가져오거나 size 정도만 조회 가능하다.

```sql
select t.members.username from Team t
```

경로 탐색을 사용한 묵시적 조인 시 주의사항

* 항상 내부 조인
* 컬렉션은 경로 탐색의 끝, 명시적 조인을 통해 별칭을 얻어야함
* 경로 탐색은 주로 SELECT, WHERE 절에서 사용하지만 묵시 적 조인으로 인해 SQL의 FROM (JOIN) 절에 영향을 줌

실무 조언

* 가급적 묵시적 조인 대신에 명시적 조인 사용
* 조인은 SQL 튜닝에 중요 포인트 • 묵시적 조인은 조인이 일어나는 상황을 한눈에 파악하기 어려움
