Oracle操作----行列转换

数据库数据如图


2017-09-15_104542.png

1、多列的数据组合到一列

select concat(id,name) str from aaa
select id||name str from aaa

结果:


2017-09-15_104718.png

2、多行的数据组合到一行

select wm_concat(name) name from aaa;

结果:


2017-09-15_105027.png

3、列转行(oracle 11G)


2017-09-15_105540.png
select name, sum(nums) nums from demo group by name
2017-09-15_105722.png
select * from (select name, nums from demo) pivot (sum(nums) for name in (' 苹果 '  苹果 , ' 橘子 ', ' 葡萄 ', ' 芒果 '));
2017-09-15_105916.png

4、行转列(Oracle 11g)


2017-09-15_110042.png
select id , name, jidu, xiaoshou from Fruit unpivot (xiaoshou for jidu in (q1, q2, q3, q4) )
注意: unpivot没有聚合函数,xiaoshou、jidu字段也是临时的变量
2017-09-15_110202.png

5、逗号分割的字符串转多行
即把


2017-09-15_110357.png

转换为:


2017-09-15_110437.png

SQL语句整理之后为:
with temp0 as (select LEVEL lv from dual CONNECT BY LEVEL <= 20)  select id,substr(t.vals,instr(t.vals, ',', 1, tv.lv) + 1, instr(t.vals, ',', 1, tv.lv + 1) -(instr(t.vals, ',', 1, tv.lv) + 1)) AS name from (select id,',' || name || ',' AS vals,  
 (length(name || ',') - nvl(length(REPLACE(name, ',')), 0)) AS cnt  
 from aaa) t join temp0 tv  
on  tv.lv <= t.cnt  order by id

重点解释:

with temp0 as (select LEVEL lv from dual CONNECT BY LEVEL <= 20) 
当在sql查询时需要对有规律的一批数据进行分析处理而又不想将这批数据存入实体表时,我们可以使用with关键字临时构建一个虚拟的数据集,以便对其进行与实体表相似的sql操作,此处我们是创建了虚拟表temp0
2017-09-15_110943.png
sql语句简化为:select id,(..1..) as name from (..2..) t join temp0 tv on  tv.lv <= t.cnt  order by id
此处用到join函数:.left join(左联接),right join(右联接),inner join(相等联接或内联接),默认为inner join(单独join时),不作详解,可以参考http://blog.csdn.net/traceofsun/article/details/6074856

(..1..)中的语句:substr(t.vals,instr(t.vals, ',', 1, tv.lv) + 1, instr(t.vals, ',', 1, tv.lv + 1) -(instr(t.vals, ',', 1, tv.lv) + 1))
函数substr:substr(字符串,截取开始位置,截取长度) //返回截取的字符串
函数instr:INSTR(源字符串, 要查找的字符串, 从第几个字符开始, 要找到第几个匹配的序号),如select INSTR('CORPORATEFLOOR','OR', 3, 2) from dual 结果为13,即查到了最后的‘OR’了

 (..2..) 中的语句:select id,',' || name || ',' AS vals,  
 (length(name || ',') - nvl(length(REPLACE(name, ',')), 0)) AS cnt  
 from aaa
',' || name || ','  :把查到的name字段前后都加上逗号
函数length:length(字符串),取字符串长度
函数REPLACE:REPLACE(源字符串,期望被替换的字符串[,期望被替换后的字符串])
函数nvl:nvl(结果表达式,默认值),如果结果表达式为空则结果=默认值,否则=结果表达式计算的结果
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容