Teradata-OLAP 함수

OLAP 함수는 집계 함수가 하나의 값만 반환하는 반면 OLAP 함수는 집계 외에 개별 행을 제공한다는 점을 제외하면 집계 함수와 유사합니다.

통사론

다음은 OLAP 함수의 일반 구문입니다.

<aggregate function> OVER  
([PARTITION BY] [ORDER BY columnname][ROWS BETWEEN 
UNBOUDED PRECEDING AND UNBOUNDED FOLLOWING)

집계 함수는 SUM, COUNT, MAX, MIN, AVG 일 수 있습니다.

다음 급여 테이블을 고려하십시오.

직원 아니요 심한 공제 순이익
101 40,000 4,000 36,000
102 80,000 6,000 74,000
103 90,000 7,000 83,000
104 75,000 5,000 70,000

다음은 Salary 테이블에서 NetPay의 누적 합계 또는 누계를 찾는 예입니다. 레코드는 EmployeeNo별로 정렬되고 누적 합계는 NetPay 열에서 계산됩니다.

SELECT  
EmployeeNo, NetPay, 
SUM(Netpay) OVER(ORDER BY EmployeeNo ROWS  
UNBOUNDED PRECEDING) as TotalSalary 
FROM Salary;

위 쿼리가 실행되면 다음과 같은 출력이 생성됩니다.

EmployeeNo     NetPay     TotalSalary 
-----------  -----------  ----------- 
   101         36000        36000 
   102         74000        110000 
   103         83000        193000 
   104         70000        263000 
   105         18000        281000

계급

RANK 함수는 제공된 열을 기반으로 레코드를 정렬합니다. RANK 함수는 순위를 기반으로 반환되는 레코드 수를 필터링 할 수도 있습니다.

통사론

다음은 RANK 함수를 사용하는 일반적인 구문입니다.

RANK() OVER 
([PARTITION BY columnnlist] [ORDER BY columnlist][DESC|ASC])

다음 Employee 테이블을 고려하십시오.

직원 아니요 이름 JoinedDate 부서 ID 생일
101 마이크 제임스 2005 년 3 월 27 일 1 1980 년 1 월 5 일
102 로버트 윌리엄스 2007 년 4 월 25 일 2 1983 년 3 월 5 일
103 베드로 2007 년 3 월 21 일 2 1983 년 4 월 1 일
104 알렉스 스튜어트 2008 년 2 월 1 일 2 1984 년 11 월 6 일
105 로버트 제임스 2008 년 1 월 4 일 1984 년 12 월 1 일

다음 쿼리는 Joined Date별로 직원 테이블의 레코드를 정렬하고 Joined Date에 순위를 할당합니다.

SELECT EmployeeNo, JoinedDate,RANK() 
OVER(ORDER BY JoinedDate) as Seniority 
FROM Employee;

위 쿼리가 실행되면 다음과 같은 출력이 생성됩니다.

EmployeeNo   JoinedDate   Seniority 
-----------  ----------  ----------- 
   101       2005-03-27       1 
   103       2007-03-21       2 
   102       2007-04-25       3 
   105       2008-01-04       4 
   104       2008-02-01       5

PARTITION BY 절은 PARTITION BY 절에 정의 된 열별로 데이터를 그룹화하고 각 그룹 내에서 OLAP 기능을 수행합니다. 다음은 PARTITION BY 절을 사용하는 쿼리의 예입니다.

SELECT EmployeeNo, JoinedDate,RANK() 
OVER(PARTITION BY DeparmentNo ORDER BY JoinedDate) as Seniority 
FROM Employee;

위 쿼리가 실행되면 다음과 같은 출력이 생성됩니다. 부서별로 랭크가 초기화되는 것을 확인할 수 있습니다.

EmployeeNo  DepartmentNo  JoinedDate   Seniority 
-----------  ------------  ----------  ----------- 

    101           1        2005-03-27       1 
    103           2        2007-03-21       1 
    102           2        2007-04-25       2 
    104           2        2008-02-01       3 
    105           3        2008-01-04       1