티스토리 뷰
- data table
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | CREATE TABLE REPORTTEST ( CUST_CODE CHAR(3) NOT NULL, SALE_DATE CHAR(8), SALE_AMT NUMBER(8) ); INSERT INTO REPORTTEST VALUES ('100','20020301',100); INSERT INTO REPORTTEST VALUES ('100','20020302',130); INSERT INTO REPORTTEST VALUES ('100','20020303',1500); INSERT INTO REPORTTEST VALUES ('100','20020304',900); INSERT INTO REPORTTEST VALUES ('100','20020304',300); INSERT INTO REPORTTEST VALUES ('100','20020305',2300); INSERT INTO REPORTTEST VALUES ('200','20020301',500); INSERT INTO REPORTTEST VALUES ('200','20020302',250); INSERT INTO REPORTTEST VALUES ('200','20020303',100); INSERT INTO REPORTTEST VALUES ('200','20020304',1500); INSERT INTO REPORTTEST VALUES ('200','20020305',3500); INSERT INTO REPORTTEST VALUES ('200','20020305',200); | cs |
1 2 3 4 5 6 7 8 9 10 | SELECT CUST_CODE, SALE_DATE, SALE_AMT, SUM(SALE_AMT) OVER (PARTITION BY CUST_CODE ORDER BY SALE_DATE ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) ACC_AMT1, SUM(SALE_AMT) OVER (PARTITION BY CUST_CODE ORDER BY SALE_DATE RANGE BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) ACC_AMT2, SUM(SALE_AMT) OVER (PARTITION BY CUST_CODE ORDER BY TO_DATE(SALE_DATE,'YYYYMMDD') RANGE BETWEEN UNBOUNDED PRECEDING AND INTERVAL '0' DAY FOLLOWING) ACC_AMT3, SUM(SALE_AMT) OVER (PARTITION BY CUST_CODE ORDER BY SALE_DATE) ACC_AMT4 FROM REPORTTEST; | cs |
result
CUS SALE_DAT SALE_AMT ACC_AMT1 ACC_AMT2 ACC_AMT3 ACC_AMT4
--- -------- ---------- ---------- ---------- ---------- ----------
100 20020301 100 100 100 100 100
100 20020302 130 230 230 230 230
100 20020303 1500 1730 1730 1730 1730
100 20020304 900 2630 2930 2930 2930
100 20020304 300 2930 2930 2930 2930
100 20020305 2300 5230 5230 5230 5230
200 20020301 500 500 500 500 500
200 20020302 250 750 750 750 750
200 20020303 100 850 850 850 850
200 20020304 1500 2350 2350 2350 2350
200 20020305 3500 5850 6050 6050 6050
200 20020305 200 6050 6050 6050 6050
- sql: PRECEDING (UNBOUNDED PRECEDING과 차이점)
1 2 3 4 5 6 7 8 9 10 11 12 13 | SELECT CUST_CODE, SALE_DATE, SALE_AMT, SUM(SALE_AMT) OVER (PARTITION BY CUST_CODE ORDER BY SALE_DATE ROWS BETWEEN 1 PRECEDING AND CURRENT ROW) ACC_AMT1, SUM(SALE_AMT) OVER (PARTITION BY CUST_CODE ORDER BY TO_DATE(SALE_DATE,'YYYYMMDD') RANGE BETWEEN 1 PRECEDING AND CURRENT ROW) ACC_AMT2, SUM(SALE_AMT) OVER (PARTITION BY CUST_CODE ORDER BY TO_DATE(SALE_DATE,'YYYYMMDD') RANGE BETWEEN INTERVAL '1' DAY PRECEDING AND CURRENT ROW) ACC_AMT3 FROM REPORTTEST; | cs |
result
CUS SALE_DAT SALE_AMT ACC_AMT1 ACC_AMT2 ACC_AMT3
--- -------- ---------- ---------- ---------- ----------
100 20020301 100 100 100 100
100 20020302 130 230 230 230
100 20020303 1500 1630 1630 1630
100 20020304 900 2400 2700 2700
100 20020304 300 1200 2700 2700
100 20020305 2300 2600 3500 3500
200 20020301 500 500 500 500
200 20020302 250 750 750 750
200 20020303 100 350 350 350
200 20020304 1500 1600 1600 1600
200 20020305 3500 5000 5200 5200
200 20020305 200 3700 5200 5200
1 2 3 4 5 6 7 8 9 10 11 12 13 | SELECT CUST_CODE, SALE_DATE, SALE_AMT, SUM(SALE_AMT) OVER (PARTITION BY CUST_CODE ORDER BY SALE_DATE ROWS BETWEEN 1 PRECEDING AND 1 FOLLOWING) ACC_AMT1, SUM(SALE_AMT) OVER (PARTITION BY CUST_CODE ORDER BY TO_DATE(SALE_DATE,'YYYYMMDD') RANGE BETWEEN 1 PRECEDING AND 1 FOLLOWING) ACC_AMT2, SUM(SALE_AMT) OVER (PARTITION BY CUST_CODE ORDER BY TO_DATE(SALE_DATE,'YYYYMMDD') RANGE BETWEEN INTERVAL '1' DAY PRECEDING AND INTERVAL '1' DAY FOLLOWING) ACC_AMT3 FROM REPORTTEST; | cs |
CUS SALE_DAT SALE_AMT ACC_AMT1 ACC_AMT2 ACC_AMT3
--- -------- ---------- ---------- ---------- ----------
100 20020301 100 230 230 230
100 20020302 130 1730 1730 1730
100 20020303 1500 2530 2830 2830
100 20020304 900 2700 5000 5000
100 20020304 300 3500 5000 5000
100 20020305 2300 2600 3500 3500
200 20020301 500 750 750 750
200 20020302 250 850 850 850
200 20020303 100 1850 1850 1850
200 20020304 1500 5100 5300 5300
200 20020305 3500 5200 5200 5200
200 20020305 200 3700 5200 5200
https://msdn.microsoft.com/ko-kr/library/ms189461(v=sql.120).aspx
'sql' 카테고리의 다른 글
sysdba 접속 불가 (0) | 2019.01.23 |
---|---|
자원 대기중 교착 상태 검출 에러 (0) | 2019.01.23 |
시퀀스 추출 (0) | 2019.01.23 |
ORACLE DB dump(pump) - Import (0) | 2018.04.29 |
ROLLUP(), CUBE(), RANK, ROW_NUMBER() (0) | 2018.03.20 |
- Total
- Today
- Yesterday
- 오라클
- 오라클시스디비에스접속
- webpack
- spring webpack 설정
- 오라클정규식함수REGEXP
- 오라클시스템계정암호
- 오라클시스템계정잠김
- spring5
- orale
- veujs
- 오라클정규식
- jsp
- srpring
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |