728x90
PRESENTV
구문
PRESENTV(cell_reference, expr1, expr2)
목적
PRESENTV 함수는 SELECT 문의 model_clause 내에서만 사용할 수 있으며, 그리고 모델 규칙의 오른쪽에만 사용할 수 있습니다. 이 함수는 model_clause의 실행 전에 cell_reference가 존재할 경우 expr1을 반환합니다. 그렇지 않으면 expr2를 반환합니다.
참고:
- 구문 및 의미에 대한 model_clause 및 "Model Expressions"
- 비교를 위한 NVL2
- Oracle Database Globalization Support Guide의 부록 C는 PRESENTV의 반환 값에 할당되는 정렬을 정의하는 정렬 파생 규칙(collation derivation rules)에 대한 정보를 제공합니다.
예제
다음 예제에서는 2000년에 Mouse Pad의 판매 내역이 있는 경우, 2001년 Mouse Pad의 판매값은 2000년 Mouse Pad의 판매값으로 설정됩니다. 해당 행이 없는 경우, 2001년 Mouse Pad의 판매값이 0으로 설정된 행이 생성됩니다.
SELECT country, prod, year, s
FROM sales_view_ref
MODEL
PARTITION BY (country)
DIMENSION BY (prod, year)
MEASURES (sale s)
IGNORE NAV
UNIQUE DIMENSION
RULES UPSERT SEQUENTIAL ORDER
(
s['Mouse Pad', 2001] =
PRESENTV(s['Mouse Pad', 2000], s['Mouse Pad', 2000], 0)
)
ORDER BY country, prod, year;
COUNTRY PROD YEAR S
---------- ----------------------------------- -------- ---------
France Mouse Pad 1998 2509.42
France Mouse Pad 1999 3678.69
France Mouse Pad 2000 3000.72
France Mouse Pad 2001 3000.72
France Standard Mouse 1998 2390.83
France Standard Mouse 1999 2280.45
France Standard Mouse 2000 1274.31
France Standard Mouse 2001 2164.54
Germany Mouse Pad 1998 5827.87
Germany Mouse Pad 1999 8346.44
Germany Mouse Pad 2000 7375.46
Germany Mouse Pad 2001 7375.46
Germany Standard Mouse 1998 7116.11
Germany Standard Mouse 1999 6263.14
Germany Standard Mouse 2000 2637.31
Germany Standard Mouse 2001 6456.13
16 rows selected.
앞의 예제는 sales_view_ref 뷰가 필요합니다. 이 뷰를 생성하려면 "The MODEL clause: Examples"를 참조하세요.
출처: 오라클 레퍼런스
원문 링크: Oracle PRESENTV 함수 문서
반응형
'코딩 > 오라클 함수' 카테고리의 다른 글
[오라클 레퍼런스 함수] RANK - 그룹 내 값의 순위 계산 (0) | 2023.08.15 |
---|---|
[오라클 레퍼런스 함수] PREVIOUS - 반복문(ITERATE) 내에서 이전 값 반환 (0) | 2023.08.14 |
[오라클 레퍼런스 함수] PRESENTNNV - model_clause 실행 전 NULL 여부에 따라 값 할당 (0) | 2023.08.14 |
[오라클 레퍼런스 함수] PREDICTION_SET - 예측 결과 세트 반환(확률 및 비용 포함) (0) | 2023.08.14 |
[오라클 레퍼런스 함수] PREDICTION_PROBABILITY - 예측 확률 반환 (분류 및 이상 탐지) (0) | 2023.08.14 |
댓글