ComputerScience/DB
With 구문
slown
2024. 9. 12. 23:31
목차
1.With구문
2.CTE?
3.문법예
1.With구문
데이터 베이스에서 with절은 SQL문을 작성하다 보면 Query를 반복해서 사용하는 경우가 발생합니다. 한 두번의 반복은 괜찮지만, 그 수가 많아질수록 가독성이 떨어지고 재사용할 수 없어 매번 동일한 Query를 작성하거나 수정해야 합니다. 이런 문제점을 해소하는데 도움이 되는게 WITH구문입니다. 이 WITH구문을 알기 위해서는 CTE라는 개념을 알아야 합니다.
2.CTE?
CTE는 common table expressions 의 약자로 SELECT, INSERT , UPDATE, DELETE 쿼리를 실행할 때, 해당 쿼리 내부에서 CTE를 사용할 수 있으며, 이는 테이블처럼 영구적으로 저장되는게 아닌 쿼리가 실행되는 동안에만 임시로 존재하는 결과값을 말합니다. 그리고 CTE는 위에 말한 WITH구문을 통해 구현을 할 수 있습니다.
3.문법예
WITH구문은 다음과 같습니다.
단일 CTE일 경우
WITH cte as (
select... )
select
*
from cte
where .....
복수의 CTE일 경우
WITH
cte1 AS (SELECT ....),
cte2 as(SELECT....)
select * from
cte1
join
cte2
on
cte.id = cte2.id;
이렇게 CTE를 작성을 하면 다음과 같은 특징이 있습니다.
- 복잡한 SQL에서 반복적으로 사용되는 서브쿼리의 블록을 하나의 WITH절 블록으로 만들어 재사용 할 수 있게 함으로써 쿼리 성능을 높일 수 있다.
- subQuery와의 차이점은 subQuery의 경우에는 쿼리내에서만 사용이 가능하고 재사용이 불가능하지만, WITH구문으로 작성을 하면 재사용을 할 수 있다는 점이 차이점입니다.