自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

數(shù)據(jù)庫(kù)中分組字符串相加

數(shù)據(jù)庫(kù)
如果想把數(shù)據(jù)庫(kù)中的數(shù)據(jù)按照固定字段分組想加,你會(huì)怎么做呢?筆者在這里總結(jié)了五種方法,也許有的你想到,也許有的你沒有想到,一起再來(lái)看看,相互學(xué)習(xí)吧。

--該測(cè)試腳本可以直接運(yùn)行

--現(xiàn)在想把數(shù)據(jù)庫(kù)中數(shù)據(jù)按照固定字段分組相加,這里總結(jié)了5種方法。

--創(chuàng)建測(cè)試表、添加測(cè)試數(shù)據(jù)

  1. create table test(id varchar2(10),mc varchar2(50));   
  2. insert into test values('1','11111');   
  3. insert into test values('1','22222');   
  4. insert into test values('2','11111');   
  5. insert into test values('2','22222');   
  6. insert into test values('3','11111');   
  7. insert into test values('3','22222');   
  8. insert into test values('3','33333');   
  9. commit

--方法一:

  1. set serveroutput on size 1000000   
  2. declare   
  3. union_mc varchar2(200);   
  4. begin   
  5. for cur_a in(select distinct id from test) loop   
  6. for cur_b in(select mc from test where id=cur_a.id) loop   
  7. union_mc:=union_mc||cur_b.mc;   
  8. end loop;   
  9. dbms_output.put_line(cur_a.id||chr(9)||union_mc);   
  10. union_mc := '';   
  11. end loop;   
  12. end;   
  13. /  

--方法二:

  1. CREATE OR REPLACE function link(v_id varchar2)   
  2. return varchar2   
  3. is   
  4. union_mc varchar2(200);   
  5. begin   
  6. for cur in (select mc from test where id=v_id) loop   
  7. union_mc := union_mc||cur.mc;   
  8. end loop;   
  9. union_mc := rtrim(union_mc,1);   
  10. return union_mc;   
  11. end;   
  12. /   
  13.  
  14. select id,link(id) from test group by id; 

--方法三:

/*從Oracle 9i開始,開發(fā)者可以創(chuàng)建用戶自定義的合計(jì)函數(shù),除了PL/SQL外,還可以使用任何Oralce所支持的語(yǔ)言(如C++或者Java)來(lái)創(chuàng)建合計(jì)函數(shù)。TYPE頭定義必須包含ODCIAggregateInitializeODCIAggregateIterateODCIAggregateMergeODCIAggregateTerminate這四個(gè)接口函數(shù)。*/

/*Initialize函數(shù)對(duì)數(shù)據(jù)組各個(gè)需要處理的字段各運(yùn)行一次。自然的,我需要為每一個(gè)值準(zhǔn)備一個(gè)新的清單,所以需要初始化持久變量list,這里初始化值為null。*/

/*Iterate函數(shù)處理返回的行,所以實(shí)際上是由它來(lái)創(chuàng)建返回的值的清單。先測(cè)試list是否為空,如果為空,就把list直接設(shè)置為所引入的value值;如果list變量非空,則給list添加一個(gè)逗號(hào)后再插入value值,list的最大允許字符數(shù)32767。*/

/*Terminate函數(shù)在數(shù)據(jù)組的每個(gè)行的感興趣字段數(shù)據(jù)被處理后執(zhí)行。在這個(gè)函數(shù)中我只需簡(jiǎn)單的返回清單變量即可。*/

/*Merge函數(shù),用來(lái)返回成功標(biāo)記的。*/

/*創(chuàng)建自己的合計(jì)函數(shù)擴(kuò)展了Oracle統(tǒng)計(jì)和文本處理能力。*/

  1. create or replace type t_cat as object   
  2. (   
  3. union_mc VARCHAR2(200),   
  4. static function ODCIAggregateInitialize(sctx IN OUT t_cat) return number,   
  5. member function ODCIAggregateIterate(self IN OUT t_cat,value IN varchar2) return number,   
  6. member function ODCIAggregateTerminate(self IN t_cat,returnValue OUT varchar2, flags IN number) return number,   
  7. member function ODCIAggregateMerge(self IN OUT t_cat,ctx2 IN t_cat) return number   
  8. );   
  9.  
  10. create or replace type body t_cat is   
  11. static function ODCIAggregateInitialize(sctx IN OUT t_cat )   
  12. return number is   
  13. begin   
  14. sctx := t_cat('');   
  15. return ODCIConst.Success;   
  16. end;   
  17. member function ODCIAggregateIterate(self IN OUT t_cat, value IN varchar2)   
  18. return number is   
  19. begin   
  20. self.union_mc := self.union_mc || value;   
  21. return ODCIConst.Success;   
  22. end;   
  23. member function ODCIAggregateTerminate(self IN t_cat, returnValue OUT varchar2, flags IN number) return number is   
  24. begin   
  25. returnValue := self.union_mc;   
  26. return ODCIConst.Success;   
  27. end;   
  28. member function ODCIAggregateMerge(self IN OUT t_cat , ctx2 IN t_cat ) return number is   
  29. begin   
  30. return ODCIConst.Success;   
  31. end;   
  32. end;   

/*如果你的Oracle服務(wù)器沒有配置成支持并行處理的方式,可以去掉參數(shù)PARALLEL_ENABLE*/

create or replace function catstr(v_mc varchar2) return varchar2 PARALLEL_ENABLE AGGREGATE USING t_cat;
/

select id,catstr(mc) from test group by id;

--方法四:

--oracle9i以上版本

  1. select id,ltrim(max(sys_connect_by_path(mc,';')),';'from(   
  2. select id,mc,row_number() over(partition by id order by id) id1,   
  3. row_number() over(order by id) + dense_rank() over(order by id) id2   
  4. from test   
  5. )   
  6. start with id1=1 connect by prior id2 = id2 -1   
  7. group by id order by id;  

方法四的另一種寫法

估計(jì)類似的寫法還有很多,這個(gè)和上一個(gè)不同在于用的沒有帶有start with(filter功能)的connect,并借助level和first_value來(lái)實(shí)現(xiàn)。

  1. SELECT distinct id,ltrim(first_value(mc_add) over (partition by id order BY l DESC),';')   
  2. from (   
  3. SELECT id,LEVEL l,sys_connect_by_path(mc,';') mc_add from   
  4. (   
  5. select id||rownum rn,id||rownum-1 rn_small,id,mc from test   
  6. )   
  7. CONNECT BY PRIOR rn = rn_small   
  8. )   

方法五:

  1. select id,wm_concat(mc) from test group by id 

原文鏈接:http://www.cnblogs.com/tracy/archive/2011/05/11/2042910.html

 

【編輯推薦】

  1. 淺述遠(yuǎn)程Service Broker的實(shí)現(xiàn)
  2. Service Broker基礎(chǔ)應(yīng)用(下)
  3. Service Broker基礎(chǔ)應(yīng)用(上)
  4. 簡(jiǎn)述Service Broker事件通知功能
  5. SQL使用中的點(diǎn)滴回憶
責(zé)任編輯:艾婧 來(lái)源: 博客園
相關(guān)推薦

2009-08-07 14:02:12

C#數(shù)據(jù)庫(kù)連接字符串

2009-08-20 17:55:43

C#連接Oracle數(shù)

2022-12-06 08:27:50

Bash腳本字符串

2010-11-26 09:46:26

MySQL字符串相加

2010-05-26 15:36:23

MySQL字符串

2010-06-04 14:59:06

MySQL數(shù)據(jù)庫(kù)

2011-07-12 14:37:47

ASP.NET鏈接字符串

2009-07-24 10:06:33

數(shù)據(jù)庫(kù)字符串ASP.NET

2011-03-22 10:44:20

SQL Server數(shù)拆分字符串函數(shù)

2010-09-13 15:50:03

sql server數(shù)

2010-06-13 18:06:06

2010-09-28 09:49:48

SQL字符串

2011-06-28 13:38:48

注冊(cè)表鍵值連接字符串

2010-06-17 15:54:04

SQL Server數(shù)

2010-06-17 16:06:07

SQL Server數(shù)

2011-08-09 16:52:24

2009-07-30 12:54:37

ASP.NET優(yōu)化性能

2010-09-28 09:42:25

sql語(yǔ)句

2010-06-17 16:30:23

SQL Server數(shù)

2009-08-20 18:13:17

C#中Access數(shù)據(jù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)