免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5120 | 回复: 1
打印 上一主题 下一主题

[数据库] oracle 行转列,求指导 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-05-17 18:00 |只看该作者 |倒序浏览
请教如何如何实现这个需求:
oracle10g的
数据表
tmp_callernob
CALLERNO    VARCHAR2(26)
NOTES        VARCHAR2(26)

部分数据:
callerno   notes
7156    本地本网
3342    本地本网
0686    本地本网
8541    本地异网
4075    本地异网
8497    本地异网
8889    异地本网
5262    异地本网
2661    异地本网
0127    异地异网
5225    异地异网
1155    异地异网

notes的值是固定的 就四种类型:  本地本网    本地异网    异地本网    异地异网;
进行行转列 ,希望得到如下结果:  

本地本网      本地异网     异地本网    异地异网   
7156              8541         8889           0127   
3342              4075          5262         5225   
0686              8497         2661         1155   
求给思路,灰常感谢

callerno 的值是可变的 有几百万条...

论坛徽章:
7
亥猪
日期:2013-10-10 17:00:29辰龙
日期:2013-10-12 16:23:19卯兔
日期:2013-11-18 17:01:27金牛座
日期:2014-09-09 10:17:052015七夕节徽章
日期:2015-08-21 11:06:172015亚冠之柏太阳神
日期:2015-09-25 13:56:42数据库技术版块每日发帖之星
日期:2016-08-06 06:20:00
2 [报告]
发表于 2013-11-15 09:29 |只看该作者
本帖最后由 li0924 于 2013-11-15 09:31 编辑

1.10G还没有pivot这个函数;11G才有这个函数;除非你有这个函数的源代码;

2.利用分区表来实现;若实现你这中效果,要用很多子查询;效率不高

3.若你这四种类型本地本网    本地异网    异地本网    异地异网;中的数据的数量都是相同的;
可以用awk来实现;总行数是S
  1. awk '{l=S/4;n=NR%l?n+1:0;a[n]=a[n]FS$1}END{for(i=0;i<=l;i++)print a[i]}' file
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP