回覆網友問題,關於一個數值和字串一起累加的問題!
回覆網友問題,關於一個數值和字串一起累加的問題![@more@]急急急!!!請各位大哥賜教一個數值和字串一起累加的問題!
SQL
CODE MONEY FLAG
-------------------- ---------- --------------------
1001 99 新建
1002 100 編輯
1002 300 新建
1002 500 取消
1002 700 編輯
1003 20 取消
1003 60 新建
7 rows selected
SQL>
SQL> select code, sm, WMSYS.WM_CONCAT(nflag) flag
2 from (select a.*, decode(ct, 2, flag || '(' || ct || ')', flag) nflag
3 from (select unique code,
4 flag,
5 count(flag) over(partition by code, flag) ct,
6 sum(money) over(partition by code) sm
7 from addtest) a) b
8 group by code, sm
9 /
CODE SM FLAG
-------------------- ---------- --------------------------------------------------------------------------------
1001 99 新建
1002 1600 新建,編輯(2),取消
1003 80 新建,取消
SQL>
oracle 9i :
關鍵字: 字串相加
一。建立測試表
CREATE TABLE addtest(
CODE VARCHAR2(20),
MONEY NUMBER,
FLAG VARCHAR2(20)
);
INSERT INTO addtest VALUES (1001, 99.00, '新建');
INSERT INTO addtest VALUES (1002, 100.00, '編輯');
INSERT INTO addtest VALUES (1002, 300.00, '新建');
INSERT INTO addtest VALUES (1002, 500.00, '取消');
INSERT INTO addtest VALUES (1002, 700.00, '編輯');
INSERT INTO addtest VALUES (1003, 20, '取消');
INSERT INTO addtest VALUES (1003, 60, '新建');
COMMIT;
select * from addtest;
二。想要得到的結果:
CODE MONEY FLAG
1001 99 新建
1002 1600 新建,編輯(2),取消
1003 80 新建,取消
拜託各位前輩大哥不吝賜教,先謝過了,小弟急啊!
oracle 10G:
一。建立測試表
CREATE TABLE addtest(
CODE VARCHAR2(20),
MONEY NUMBER,
FLAG VARCHAR2(20)
);
INSERT INTO addtest VALUES (1001, 99.00, '新建');
INSERT INTO addtest VALUES (1002, 100.00, '編輯');
INSERT INTO addtest VALUES (1002, 300.00, '新建');
INSERT INTO addtest VALUES (1002, 500.00, '取消');
INSERT INTO addtest VALUES (1002, 700.00, '編輯');
INSERT INTO addtest VALUES (1003, 20, '取消');
INSERT INTO addtest VALUES (1003, 60, '新建');
COMMIT;
select * from addtest;
二。想要得到的結果:
CODE MONEY FLAG
1001 99 新建
1002 1600 新建,編輯(2),取消
1003 80 新建,取消
拜託各位前輩大哥不吝賜教,先謝過了,小弟急啊!
oracle 10G:
SQL
select a.code,fl,money from
2 (select code,substr(sys_connect_by_path(falg,','),2) fl,money,level le from
3 (select row_number() over(order by code) rn,code,
4 decode(count(flag),1,flag,flag||'('||count(flag)||')') falg
5 ,sum(sum(money)) over(partition by code) money from addtest group by code,flag)
6 connect by prior code=code and prior rn+1=rn) a
7 ,(select code,count(distinct flag) co from addtest group by code) b
8 where a.le=b.co and a.code=b.code;
2 (select code,substr(sys_connect_by_path(falg,','),2) fl,money,level le from
3 (select row_number() over(order by code) rn,code,
4 decode(count(flag),1,flag,flag||'('||count(flag)||')') falg
5 ,sum(sum(money)) over(partition by code) money from addtest group by code,flag)
6 connect by prior code=code and prior rn+1=rn) a
7 ,(select code,count(distinct flag) co from addtest group by code) b
8 where a.le=b.co and a.code=b.code;
i did :
SELECT code,sm,LTRIM(MAX(SYS_CONNECT_BY_PATH(nflag,',')),',') nflag
from
(
select code,sm,nflag,MIN(nflag) OVER(PARTITION BY code) nflag_MIN,
(ROW_NUMBER() OVER(ORDER BY code,sm,nflag))+(DENSE_RANK() OVER (ORDER BY code,sm)) NUMID
from
(
select code,sm,decode(ct, 2, flag || '(' || ct || ')', flag) nflag
from (select unique code,
flag,
count(flag) over(partition by code, flag) ct,
sum(money) over(partition by code) sm
from addtest) a
)b
)c
START WITH nflag=nflag_MIN CONNECT BY NUMID-1=PRIOR NUMID
GROUP BY code,sm;
> select * from addtest;from
(
select code,sm,nflag,MIN(nflag) OVER(PARTITION BY code) nflag_MIN,
(ROW_NUMBER() OVER(ORDER BY code,sm,nflag))+(DENSE_RANK() OVER (ORDER BY code,sm)) NUMID
from
(
select code,sm,decode(ct, 2, flag || '(' || ct || ')', flag) nflag
from (select unique code,
flag,
count(flag) over(partition by code, flag) ct,
sum(money) over(partition by code) sm
from addtest) a
)b
)c
START WITH nflag=nflag_MIN CONNECT BY NUMID-1=PRIOR NUMID
GROUP BY code,sm;
CODE MONEY FLAG
-------------------- ---------- --------------------
1001 99 新建
1002 100 編輯
1002 300 新建
1002 500 取消
1002 700 編輯
1003 20 取消
1003 60 新建
7 rows selected
SQL>
SQL> select code, sm, WMSYS.WM_CONCAT(nflag) flag
2 from (select a.*, decode(ct, 2, flag || '(' || ct || ')', flag) nflag
3 from (select unique code,
4 flag,
5 count(flag) over(partition by code, flag) ct,
6 sum(money) over(partition by code) sm
7 from addtest) a) b
8 group by code, sm
9 /
CODE SM FLAG
-------------------- ---------- --------------------------------------------------------------------------------
1001 99 新建
1002 1600 新建,編輯(2),取消
1003 80 新建,取消
SQL>
oracle 9i :
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/101162/viewspace-1011826/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 關於一個網友最佳化問題的解決
- 一個關於值傳遞呼叫的問題
- 回覆java_gh的一個問題Java
- 關於教程的一個問題
- 關於css權值的問題CSS
- 問一個關於hibernate的OracleDialect問題Oracle
- 回覆關於原始碼沙盒防洩密的四個問題原始碼
- 陣列累加和問題三連陣列
- 關於int型別數值的運算問題型別
- 關於Integer面試的一個問題面試
- 一個關於Java Excel的問題JavaExcel
- 一個關於SessionBean呼叫的問題。SessionBean
- 一個關於prototype模式的問題?模式
- 請教一個問題,關於上傳檔案和圖片的問題
- 關於一個歸檔問題?
- 一些關於VB中字串操作的問題和回答 (轉)字串
- 關於FILE_MODE值的問題,!!!!!
- 關於回覆資料後,登入不上的問題
- 有關C++引數傳值的一個問題探討C++
- 關於Session值丟失問題Session
- 求助關於JdonFrameworkTest的一個問題Framework
- 關於系統效能的一個問題
- 一個關於jdbc2的問題JDBC
- 關於jdbc的一個問題,高手解惑JDBC
- 關於抽象工廠的一個問題?抽象
- 爭用!!!!一個關於JDBC的問題!JDBC
- 關於singleton模式的一個問題?模式
- 碰到一個棘手的問題——關於httpclient。HTTPclient
- 關於網路的一點問題(轉)
- 一個關於c++字串處理和delete[]與delete差別的問題 (轉)C++字串delete
- 關於值物件的驗證的問題物件
- 請問老師一個關於命令模式的問題模式
- 關於網路安全幾個問題的整理
- 關於字串中取相同的字元問題(小學題)字串字元
- 問一個關於oracle8的簡單的問題!Oracle
- 請問一個關於web的管理系統的問題Web
- 關於實體與值物件的問題物件
- 高手都進來歇歇~解決一個問題關於SE的問題