oracle sql列转行_oracle 列转行

oracle sql列转行_oracle 列转行业务中做报表,需要将一列列数据汇总成一行,然后汇总,如下:需要将每个产品进行汇总,通过ichartjs进行展示,图表中需要数据的顺序是:Java代码vardata=[{name:’产品1′,value:[145,192,198,180],color:’#dad81f’},{name:’产品2′,value:[135,210,180,210],color:’#1f7e92’…

大家好,又见面了,我是你们的朋友全栈君。

业务中做报表,需要将一列列数据汇总成一行,然后汇总,如下:

oracle sql列转行_oracle 列转行

需要将每个产品进行汇总,通过ichartjs进行展示,图表中需要数据的顺序是:

Java代码 oracle sql列转行_oracle 列转行oracle sql列转行_oracle 列转行

oracle sql列转行_oracle 列转行

var data = [

{ name :’产品1′, value:[145,192,198,180], color:’#dad81f’},

{ name :’产品2′, value:[135,210,180,210], color:’#1f7e92′},

{ name :’产品3′, value:[198,210,198,198], color:’#76a871′},

];

var labels = [“2013-10-10 13:21”,

“2013-10-10 13:22”,

“2013-10-10 13:23”,

“2013-10-10 13:24”];

var data = [

{ name : ‘产品1′, value:[145,192,198,180], color:’#dad81f’ },

{ name : ‘产品2′, value:[135,210,180,210], color:’#1f7e92’ },

{ name : ‘产品3′, value:[198,210,198,198], color:’#76a871’ },

];

var labels = [“2013-10-10 13:21”,

“2013-10-10 13:22”,

“2013-10-10 13:23”,

“2013-10-10 13:24”];

如果直接用oracle 列转行函数 WMSYS.WM_CONCAT 函数处理,结果会没有排序效果:

Sql代码 oracle sql列转行_oracle 列转行oracle sql列转行_oracle 列转行

oracle sql列转行_oracle 列转行

SELECTNAME,WMSYS.WM_CONCAT(counter) counterFROMa_test tGROUPBYNAME

SELECT NAME,WMSYS.WM_CONCAT(counter) counter FROM a_test t GROUP BY NAME

结果最后一位与第二位错位:

oracle sql列转行_oracle 列转行

突然想,进行排序后拼接呢?

Sql代码 oracle sql列转行_oracle 列转行oracle sql列转行_oracle 列转行

oracle sql列转行_oracle 列转行

SELECTNAME,WMSYS.WM_CONCAT(counter) counterFROMa_test tORDERBYNAMEGROUPBYNAME

SELECT NAME,WMSYS.WM_CONCAT(counter) counter FROM a_test t ORDER BY NAME GROUP BY NAME

不行!语句根本就不通!在内部进行排序再拼接呢?

Sql代码 oracle sql列转行_oracle 列转行oracle sql列转行_oracle 列转行

oracle sql列转行_oracle 列转行

SELECTt.NAME, WMSYS.WM_CONCAT(counter) counterFROM(SELECTNAME,counterFROMa_testWHEREUTC < 13ORDERBYUTCASC) TGROUPBYNAME

SELECT t.NAME, WMSYS.WM_CONCAT(counter) counter FROM (SELECT NAME,counter FROM a_test WHERE UTC < 13 ORDER BY UTC ASC) T GROUP BY NAME

结果是:

oracle sql列转行_oracle 列转行

跟上面一样,都不行。最后不用分组来处理,发现结果能实现排序,不过就是记录多了点:

Sql代码 oracle sql列转行_oracle 列转行oracle sql列转行_oracle 列转行

oracle sql列转行_oracle 列转行

SELECTNAME,

WMSYS.WM_CONCAT(counter) OVER(PARTITIONBYNAMEORDERBYNAME,UTC)KEY,

row_number() over(PARTITIONBYNAMEORDERBYNAMEdesc) rs

froma_test

SELECT NAME,

WMSYS.WM_CONCAT(counter) OVER(PARTITION BY NAME ORDER BY NAME,UTC) KEY,

row_number() over(PARTITION BY NAME ORDER BY NAME desc) rs

from a_test

oracle sql列转行_oracle 列转行

怎么办? ……….哦………..外围加个查询语句,来个分组取最大值,怎么样?

通过oracle 列转行函数 WMSYS.WM_CONCAT创建语句如下:

Sql代码 oracle sql列转行_oracle 列转行oracle sql列转行_oracle 列转行

oracle sql列转行_oracle 列转行

SELECTA.NAME,MAX(KEY)AScounterFROM(SELECTNAME,

WMSYS.WM_CONCAT(counter) OVER(PARTITIONBYNAMEORDERBYNAME,UTC)KEY,

row_number() over(PARTITIONBYNAMEORDERBYNAMEdesc) rs

froma_test ) A

GROUPBYNAME

SELECT A.NAME,MAX(KEY) AS counter FROM (SELECT NAME,

WMSYS.WM_CONCAT(counter) OVER(PARTITION BY NAME ORDER BY NAME,UTC) KEY,

row_number() over(PARTITION BY NAME ORDER BY NAME desc) rs

from a_test ) A

GROUP BY NAME

得到结果

oracle sql列转行_oracle 列转行

到此,通过oracle 列转行函数 WMSYS.WM_CONCAT进行排序结束,结果令人满意。

总结:

1. 记录下来,给以后的自己和需要的人来点灵感,遇到问题后要一步步的分析逻辑,哪怕第一个主意不能解决问题,关键要开动脑筋想。

2. oracle的函数不一定能解决问题,有时候很多技巧加很多函数才是解决方案。

3. 注意,如果在产品根据分组的条件(本列子中是将数据分四组,是按照时间分组的)不能确定,或者会不规则,就不能使用这个方案来处理,比如分组的时间中间有一个断档了,结果就不正确:

oracle sql列转行_oracle 列转行

看看,结果永远是下面这个:

oracle sql列转行_oracle 列转行

其实我们要的是这样的(注意最后一排逗号中间的空格):

Sql代码 oracle sql列转行_oracle 列转行oracle sql列转行_oracle 列转行

oracle sql列转行_oracle 列转行

NAMECOUNTER

1 产品1 145,192,198,180,167,166

2 产品2 135,210,180,210,188,164

3 产品3 198,210,198,198,,165

NAMECOUNTER

1产品1145,192,198,180,167,166

2产品2135,210,180,210,188,164

3产品3198,210,198,198,,165

遇到这种情况,就可能需要程序来处理。我目前还没有找到oracle的解决方案。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/148270.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • ILSVRC竞赛详细介绍(ImageNet Large Scale Visual Recognition Challenge)

    ILSVRC(ImageNetLargeScaleVisualRecognitionChallenge)是近年来机器视觉领域最受追捧也是最具权威的学术竞赛之一,代表了图像领域的最高水平。ImageNet数据集是ILSVRC竞赛使用的是数据集,由斯坦福大学李飞飞教授主导,包含了超过1400万张全尺寸的有标记图片。ILSVRC比赛会每年从ImageNet数据集中抽出部分样本,以2012年为…

    2022年4月5日
    296
  • SAP WebIDE里OData service catalog的实现原理「建议收藏」

    SAP WebIDE里OData service catalog的实现原理「建议收藏」我们在SAPWebIDE里创建UI5应用时,可以从Servicecatalog里选择需要的OData服务,如下图所示:这个ag3-backend是什么意思?是我在SAPCloudPlatform的Destination标签页里维护的一个Destination:这个destination指向了一个OnpremiseABAPNetweaver系统,AG3,通过SAPCloud…

    2022年10月18日
    4
  • 数仓ODS层建设_实时数仓架构

    数仓ODS层建设_实时数仓架构一、ODS层辨析ODS全称是OperationalDataStore,即操作数据存储。1.InmonVSKimballBill.Inmon的定义:ODS是一个面向主题的、集成的、可变的、当前的细节数据集合,用于支持企业对于即时性的、操作性的、集成的全体信息的需求。常常被作为数据仓库的过渡,也是数据仓库项目的可选项之一。而Kimball的定义:操作型系统的集成,用于当前、历史以及其它细节查询(业务系统的一部分);为决策支持提供当前细节数据(数据仓库的一部分)。2.ODSVSDB

    2022年10月5日
    4
  • 解决微信H5获取SDK授权报错提示errMsg: “config:fail,Error: 系统错误,错误码:63002,invalid signature [20200908 22:17:17][]“

    解决微信H5获取SDK授权报错提示errMsg: “config:fail,Error: 系统错误,错误码:63002,invalid signature [20200908 22:17:17][]“如果常规检查都做过可以仔细看下https://developers.weixin.qq.com/doc/offiaccount/Getting_Started/Global_Return_Code.html这个里面的报错原因如果都不是那么极有可能是(看样子你的H5页面日活人数还蛮多[呲牙])获取腾讯微信平台access_token超过每日默认上限2000次导致无法获取本地地理信息坐标,通常会报错errMsg:”config:fail,Error:系统错误,错误码:63002,invali…

    2025年6月16日
    4
  • vboxmanage的使用

    vboxmanage的使用下面介绍使用VboxManage来进行操作系统的安装1、首先我们需要安装和Virtualbox对应版本的扩展包vboxmanageextpackinstallxxx.vbox-extpack查看已经安装的扩展包命令:VBoxManagelistextpack…

    2022年6月6日
    65
  • Android开发规范「建议收藏」

    1.java代码中不出现中文,最多注释中可以出现中文2.局部变量命名、静态成员变量命名只能包含字母,名字中每个单词首字母都为大写(第一个单词首字母除外),其他都为小写3.常量命名只能包含字母和_,字母全部大写,单词之间用_隔开4.layout中的id命名命名模式为:view缩写_模块名称_view的逻辑名称view的缩写详情如下LayoutView:lvRela

    2022年3月9日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号