`

oracle 列转行函数 WMSYS.WM_CONCAT 排序不规则处理

 
阅读更多

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



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

 

 

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 函数处理,结果会没有排序效果:

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

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



 

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

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

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

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

 结果是:



 

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

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 列转行函数 WMSYS.WM_CONCAT创建语句如下:

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 列转行函数 WMSYS.WM_CONCAT进行排序结束,结果令人满意。

总结:

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

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

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



 

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

 

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

   	NAME	COUNTER
1	产品1	145,192,198,180,167,166
2	产品2	135,210,180,210,188,164
3	产品3	198,210,198,198,,165

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

 

 

 

 

 

 

 

  • 大小: 14.2 KB
  • 大小: 3.5 KB
  • 大小: 3.7 KB
  • 大小: 8.1 KB
  • 大小: 20.7 KB
  • 大小: 4.1 KB
4
3
分享到:
评论
3 楼 chwshuang 2014-11-13  
dgncye929 写道
其实,加上 distinct 就可解决问题:

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

原出处:

http://stackoverflow.com/questions/4970477/oracle-sql-wm-concat-order-by



谢谢~!
2 楼 dgncye929 2014-11-06  
其实,加上 distinct 就可解决问题:

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

原出处:

http://stackoverflow.com/questions/4970477/oracle-sql-wm-concat-order-by
1 楼 education_study 2014-03-13  
帮了我大忙了~~

相关推荐

    重建WMSYS用户的WMSYS.WM_CONCAT函数的3个文件

    在Oracle数据库环境中,WMSYS.WM_CONCAT函数是一个用于字符串连接的实用工具,尤其在处理多值列时非常有用。然而,有时由于各种原因,这个函数可能丢失或损坏,需要进行重建。以下是对重建WMSYS.WM_CONCAT函数涉及的...

    Oracle 11g 重建WMSYS.WM_CONCAT函数

    Oracle10g之后有些版本已不包含WMSYS.WM_CONCAT函数,若用到此函数, 系统会提示异常:ORA-00904: "WM_CONCAT": invalid identifier 因此需单独重建此函数,方法如下: 解压附件,在sqlplus中执行包里的owmctab....

    wmsys.wm_concat详细示例.txt

    在Oracle数据库中,`wmsys.wm_concat`是一个非常实用且强大的函数,主要用于将多个字符串连接成一个字符串。此函数常用于数据聚合场景,尤其是当需要在一个查询中汇总特定分组下的所有值时。根据给定文件的信息,...

    ORA-00904 WMSYS.WM_CONCAT标识符无效解决方案

    在这种情况下,错误是针对"WMSYS.WM_CONCAT"函数的,这是一个在某些Oracle版本中提供的聚合函数,用于字符串连接。然而,从Oracle 11g Release 2开始,这个函数被弃用了,并在后续版本中完全移除,导致了“标识符...

    oracle行转列聚合函数WMSYS.WM_CONCAT

    ### Oracle行转列聚合函数WMSYS.WM_CONCAT详解 #### 一、概述 在进行数据处理时,经常会遇到需要将多行数据合并为单行的情况,这通常被称为“行转列”。Oracle数据库提供了多种方法来实现这一需求,其中`WMSYS.WM_...

    类似于wmsys.wm_concat的自定义函数clob版

    在Oracle数据库中,`WMSYS.WM_CONCAT`函数是一个非常实用的工具,它用于将多行数据合并成一个单行字符串。然而,由于其内部处理机制,当需要合并的数据量过大时,可能会遇到“字符串缓冲区太小”的错误。这是因为`WM...

    Oracle重建WMSYS用户及WMSYS.WM_CONCAT函数

    解决ORA-00904: "WMSYS"."WM_CONCAT": 标识符无效 在sqlplus中执行包里的owmctab.plb、owmaggrs.plb、owmaggrb.plb三个脚本即可。 简单来说,用PL/SQL执行下一下几个脚本就可以了。 特别要注意:PL/SQL登录时,要...

    wmsys_wm_concat函数结果拆解

    在Oracle数据库中,`wmsys.wm_concat`是一个常用的数据处理函数,主要用于连接字符串。它能够接受多个参数,并将这些参数用逗号分隔的形式存储为一个字符串。此函数广泛应用于数据仓库或报表系统中,特别是在需要将...

    wmsys 用户 没有WMSYS.WM_CONCAT方法

    没有WMSYS.WM_CONCAT方法 需要的文件 owmctab.plb owmaggrs.plb owmaggrb.plb 拷贝三个文件到 $ORACLE_HOME\RDBMS\ADMIN\ 目录下 打开命令行 sqlpus , 用sys 登陆 执行命令 @$ORACLE_HOME\RDBMS\ADMIN\owmctab.plb...

    Oracle重建WMSYS用户及WMSYS.WM_CONCAT函数(更低分)

    这个错误通常意味着试图访问或使用`WMSYS.WM_CONCAT`函数时遇到了问题,这是一个在早期Oracle版本中提供的聚合函数,用于字符串连接,但在较新的版本中被弃用并替换为其他更安全和高效的解决方案。 `WMSYS`是Oracle...

    ORA-00904: "WM_CONCAT": 标识符无效

    在这个场景下,错误信息提到的是"WM_CONCAT"函数,这表明在Oracle 19c数据库环境中,用户尝试使用WM_CONCAT函数,但系统无法识别该函数,提示其为无效的标识符。WM_CONCAT是Oracle 10g及更早版本中用于字符串合并的...

    wmsys_wm_concat的几个用法

    wmsys_wm_concat的几个用法/wmsys_wm_concat的几个用法/wmsys_wm_concat的几个用法/wmsys_wm_concat的几个用法/wmsys_wm_concat的几个用法

    oracle中将列拼接字段函数

    本文将详细介绍如何使用Oracle中的`WMSYS.WM_CONCAT`函数来实现列的拼接,并通过具体的例子帮助理解其应用场景。 ### Oracle中的WMSYS.WM_CONCAT函数 #### 函数介绍 `WMSYS.WM_CONCAT`函数是Oracle提供的一个用于...

    oracle—SQL技巧之(二)WMSYS.WM_CONCAT函数实现多行记录用逗号拼接在一起

    总之,`WMSYS.WM_CONCAT`函数在Oracle中提供了一种方便的方式来合并多行数据,但需要谨慎处理其输出长度限制。通过上述方法,我们可以在不超过限制的情况下,有效地展示大量记录的概览,满足用户的需求。不过,需要...

    重建WMSYS用户.zip

    WMSYS.WM_CONCAT是Oracle Spatial中的一个函数,用于处理多行文本数据的连接操作,但在某些情况下可能会出现"标识符无效"的错误。这个问题通常出现在数据库升级、恢复或者对象权限出现问题时。 当您遇到“WMSYS.WM_...

    Oracle10g自定义聚合函数(字符串拼接)

    * 自定义聚合函数 wmsys.wm_concat 替换办法 * 超大字符串拼接,单个字符串4000、分隔符100,可拼出超4000的超长字符串 * 可自定义指定分隔符separator * 可自定义指定排序字段sequence,对于数字或日期类型的...

Global site tag (gtag.js) - Google Analytics