문돌이 존버/DB 및 SQL 스터디

SQLD RANK(), PARTITION BY, EXISTS(), LPAD() 예제

애뚱 2021. 3. 5. 21:53
반응형

1. 윈도우 함수(Window Function): 여러 행 간의 관계 정의 함수, 중첩 불가

RANK(): 중복 순위 포함
SELECT cost_center, RANK() OVER (ORDER BY cost_center DESC) AS rk
FROM employees;

DENSE_RANK(): 중복 순위 무시
SELECT cost_center, DENSE_RANK() OVER (ORDER BY cost_center DESC) AS rk
FROM employees;

2. 윈도우 함수 문법

PARTITION BY: 그룹핑 기준
SELECT deptno, ename, sal, 
RANK() OVER (PARTITION BY deptno ORDER BY sal DESC ) as rk 
FROM emp ;

3. 서브쿼리 다중행 비교 연산자

WHERE EXISTS: 서브쿼리의 결과를 만족하는 값이 존재하는지 여부를 확인하는 조건

상관 서브쿼리의 칼럼을 테이블 별칭으로 한정하지 않으면, 서브쿼리 테이블의 칼럼을 우선적으로 검색한다. 즉 아래에서 dname은 dept 테이블의 dname 컬럼이라고 인식하게 된다. 따라서 X.dname = dname 조건은 항상 True기 때문에 emp 테이블의 전체 행이 반환된다. 

SELECT *
FROM emp A
WHERE EXISTS (SELECT 1
              FROM dept X
              WHERE X.dname = dname);
              
# 서브쿼리의 SELECT 1은 단순히 값이 존재하는지를 알려주는 지표일뿐, 숫자 1은 아무 의미가 없다
# 1 대신 0, 2 등으로 해도 무방하다

4. LPAD(), RPAD() 함수

LPAD: 지정한 길이만큼 왼쪽부터 특정한 문자로 채운다

LPAD("값", "총 문자길이", "채움문자") 

SELECT empno
     ,ename
     ,deptno
     ,LPAD(deptno, 5)      --1 # 채움문자를 지정하지 않으면 디폴트값은 공백
     ,LPAD(deptno, 5, ' ') --2
     ,LPAD(deptno, 5, '0') --3
     ,LPAD(deptno, 5, 'A') --4
  FROM emp;

RPAD: 지정한 길이만큼 오른쪽부터 특정한 문자로 채운다

RPAD("값", "총 문자길이", "채움문자") 

SELECT empno
     ,ename
     ,deptno
     ,RPAD(deptno, 5)      --1 
     ,RPAD(deptno, 5, ' ') --2
     ,RPAD(deptno, 5, '0') --3
     ,RPAD(deptno, 5, 'A') --4
  FROM emp;

728x90
반응형