最近2018中文字幕在日韩欧美国产成人片_国产日韩精品一区二区在线_在线观看成年美女黄网色视频_国产精品一区三区五区_国产精彩刺激乱对白_看黄色黄大色黄片免费_人人超碰自拍cao_国产高清av在线_亚洲精品电影av_日韩美女尤物视频网站

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
oracle如何合并行,oracle 合并行

求助,oracle多行數(shù)據(jù)合并成一行

我現(xiàn)在身邊沒有 數(shù)據(jù)庫環(huán)境 這個(gè)是我以前寫的SQL

成都創(chuàng)新互聯(lián)公司專注于灤南企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站開發(fā),商城網(wǎng)站建設(shè)。灤南網(wǎng)站建設(shè)公司,為灤南等地區(qū)提供建站服務(wù)。全流程按需定制網(wǎng)站,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)

你看一下,修改一下就可以了

Oracle分組查詢用逗號(hào)分隔結(jié)果SQL語句

表一:

學(xué)號(hào) 姓名

1 張三

2 李四

3 王五

。。。。

表二:

學(xué)號(hào) 選修課程

1 語文

1 數(shù)學(xué)

2 英語

2 語文

3 數(shù)學(xué)

3 英語

3 歷史

。。。。。

要求查處結(jié)果

學(xué)好 姓名 選修課程所有課程名稱以,隔開

1 張三 語文,數(shù)學(xué)

2 李四 英語,語文

3 王五 數(shù)學(xué),英語,歷史

;

create table a_lyh_test

as

select 1 as "學(xué)號(hào)" , '張三' as "姓名" from dual

union all

select 2 as "學(xué)號(hào)" , '李四' as "姓名" from dual

union all

select 3 as "學(xué)號(hào)" , '王五' as "姓名" from dual

;

create table b_lyh_test

as

select 1 as "學(xué)號(hào)" , '語文' as "選修課程" from dual

union all

select 1 as "學(xué)號(hào)" , '數(shù)學(xué)' as "選修課程" from dual

union all

select 2 as "學(xué)號(hào)" , '英語' as "選修課程" from dual

union all

select 2 as "學(xué)號(hào)" , '語文' as "選修課程" from dual

union all

select 3 as "學(xué)號(hào)" , '數(shù)學(xué)' as "選修課程" from dual

union all

select 3 as "學(xué)號(hào)" , '英語' as "選修課程" from dual

union all

select 3 as "學(xué)號(hào)" , '歷史' as "選修課程" from dual

;

select f."學(xué)號(hào)"

,f."姓名"

,ltrim(max(sys_connect_by_path(f."選修課程",','))

keep (dense_rank last order by f.pnum),',') as "選修課程"

from

(

select t."學(xué)號(hào)"

,t."姓名"

,t."選修課程"

,row_number() over(partition by t."學(xué)號(hào)" order by t."姓名") as pnum

,row_number() over(partition by t."學(xué)號(hào)" order by t."姓名")-1 as lnum

from

(

select a."學(xué)號(hào)",a."姓名",b."選修課程"

from a_lyh_test a

,b_lyh_test b

where a."學(xué)號(hào)" = b."學(xué)號(hào)"

) t

) f

group by f."學(xué)號(hào)",f."姓名"

connect by f.lnum = prior f.pnum and f."學(xué)號(hào)" = prior f."學(xué)號(hào)"

start with f.pnum = 1;

在Oracle中,如何將多行數(shù)據(jù)合并成一行數(shù)據(jù),如下:

如果這兩行有個(gè)共同的其他列作為分組,標(biāo)志他們是同一組、比如姓名編號(hào)之類的,是可以group by后min出來的。

select 姓名,min(引流管) as 引流管,min(化療) as 化療, min(放療) as 放療

from 記錄表

group by 姓名

;

oracle 兩行數(shù)據(jù)合并為一行數(shù)據(jù)

合并可以做到,不過如果不是單一的一條記錄,那不就變成笛卡爾積了?

比如有兩行不同姓名的行,再有兩行不同姓名1的行。

那么你得到的結(jié)果就是4行(也就是笛卡爾積),而且內(nèi)容全不完全都不同,這個(gè)結(jié)果應(yīng)該不是你要的吧。

比如前面的兩行內(nèi)容為a a a;b b b(一個(gè)字母表示一個(gè)字段,這是兩行內(nèi)容)

后面兩行的內(nèi)容為c c c;d d d(一個(gè)字母表示一個(gè)字段,這是兩行內(nèi)容)

那么你得到的結(jié)果就是 a a a c c c;a a a d d d;b b b c c c;b b b d d d

這個(gè)四行的結(jié)果是你要的么?


網(wǎng)站欄目:oracle如何合并行,oracle 合并行
當(dāng)前URL:http://fisionsoft.com.cn/article/dsiddsp.html