일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- appspresso
- phonegap
- Ajax
- Struts
- JSON
- Eclipse
- swingx
- MFC
- PLSQL
- JDOM
- oracle
- rowspan
- 선택적조인
- dock
- 가우스
- GPS
- jQuery
- tomcat
- Google Map
- WebLogic
- Android
- ibsheet
- 전자정부프레임워크
- sencha touch
- iBATIS
- PHP
- jsr 296
- Spring
- MySQL
- node.js
- Today
- Total
Where The Streets Have No Name
SQL의 기본 함수만 사용하여 누적곱을 구하는 방법 본문
1. 적용원리
. 임의의 숫자의 곱을 숫자의 합 형태로 변경한다.
- e^(ln X) = X
- e^(ln X + ln Y) = e^(ln (X * Y)) = X * Y
2. 샘플
CREATE TABLE test(
id number,
col1 number);
INSERT INTO test VALUES(1, 5);
INSERT INTO test VALUES(2, 10);
INSERT INTO test VALUES(3, 7);
INSERT INTO test VALUES(4, 10);
SQL> SELECT id, col1, EXP(m) multiply
FROM (
SELECT id, col1, SUM(LN(col1)) OVER (ORDER BY id) m
FROM test
);
ID COL1 MULTIPLY
---------- ---------- ----------
1 5 5
2 10 50
3 7 350
4 10 3500
SQL> SELECT EXP(SUM(LN(col1)))
FROM test ;
EXP(SUM(LN(COL1)))
------------------
3500
Ithe ln function returns the natural logarithm of a number.