Oracle10g以上的版本中提供了转换组合函数。
例如表test_t的原始数据查询结果为:
select * from latty.test_t
1 200405 5761 G 7393344.04
2 200405 5761 J 5667089.85
3 200405 5762 G 6315075.96
4 200405 5762 J 6328716.15
5 200405 5763 G 7393344.04
6 200405 5763 J 5667089.85
7 200405 5764 G 6028670.45
8 200405 5764 J 6459121.49
9 200405 5765 G 13156065.77
10 200405 5765 J 11901671.70
11 200406 5761 G 7614587.96
12 200406 5761 J 5704343.05
13 200406 5762 G 6556992.60
14 200406 5762 J 6238068.05
15 200406 5763 G 7614587.96
16 200406 5763 J 5704343.05
17 200406 5764 G 6387706.01
18 200406 5764 J 6907481.66
19 200406 5765 G 13562968.81
20 200406 5765 J 12495492.50
21 200407 5761 G 7987050.65
22 200407 5761 J 5723215.28
23 200407 5762 G 6833096.68
24 200407 5762 J 6391201.44
25 200407 5763 G 7987050.65
26 200407 5763 J 5723215.28
27 200407 5764 G 6456433.23
28 200407 5764 J 6987660.53
29 200407 5765 G 14000101.20
30 200407 5765 J 12301780.20
31 200408 5761 G 8085170.84
32 200408 5761 J 6050611.37
33 200408 5762 G 6854584.22
34 200408 5762 J 6521884.50
35 200408 5763 G 8085170.84
36 200408 5763 J 6050611.37
37 200408 5764 G 6587559.23
比如现在查看这条SQL:
select wm_concat(area_code) 用户名 from latty.test_t group by bill_month;
执行结果为:
1 5761,5761,5762,5763,5764,5765,5765,5764,5763,5762
2 5761,5762,5763,5764,5765,5765,5764,5763,5762,5761
3 5761,5764,5765,5765,5764,5763,5761,5762,5763,5762
4 5761,5762,5762,5763,5764,5763,5761
分享到:
相关推荐
在Oracle数据库环境中,WMSYS.WM_CONCAT函数是一个用于字符串连接的实用工具,尤其在处理多值列时非常有用。然而,有时由于各种原因,这个函数可能丢失或损坏,需要进行重建。以下是对重建WMSYS.WM_CONCAT函数涉及的...
在这个场景下,错误信息提到的是"WM_CONCAT"函数,这表明在Oracle 19c数据库环境中,用户尝试使用WM_CONCAT函数,但系统无法识别该函数,提示其为无效的标识符。WM_CONCAT是Oracle 10g及更早版本中用于字符串合并的...
在Oracle数据库中,WM_CONCAT是一个非常实用的聚合函数,用于将一组字符串连接成一个单一的字符串,类似于SQL Server中的STRING_AGG或MySQL中的GROUP_CONCAT。然而,Oracle官方并没有提供这个函数,它是一个第三方...
### Oracle行转列聚合函数WMSYS.WM_CONCAT详解 #### 一、概述 在进行数据处理时,经常会遇到需要将多行数据合并为单行的情况,这通常被称为“行转列”。Oracle数据库提供了多种方法来实现这一需求,其中`WMSYS.WM_...
Oracle中的WM_CONCAT函数是一个非标准的聚合函数,主要用于将多行数据合并成单行,以逗号分隔的形式返回。这个函数在处理特定的数据汇总和报告需求时非常有用,尤其是在你需要将某个列的多个值合并成一个字符串时。...
在SQL Server 2012中,引入了一个新的字符串函数——CONCAT,它的主要功能是方便地连接多个字符串。在CONCAT函数出现之前,我们通常使用 "+" 运算符来连接字符串,但这种方法存在一个问题,即如果其中任何一个字符串...
### Oracle函数介绍(一):著名函数之单值 在Oracle数据库系统中,函数是非常重要的组成部分,它们提供了强大的数据...在未来的学习过程中,建议深入研究更多复杂的函数组合和用法,以便更好地应对实际工作中的挑战。
本文将详细介绍如何使用Oracle中的`WMSYS.WM_CONCAT`函数来实现列的拼接,并通过具体的例子帮助理解其应用场景。 ### Oracle中的WMSYS.WM_CONCAT函数 #### 函数介绍 `WMSYS.WM_CONCAT`函数是Oracle提供的一个用于...
WMSYS.WM_CONCAT函数是这个系统中的一个重要组成部分,用于处理字符串的连接操作,尤其在数据仓库的ETL(Extract, Transform, Load)过程中十分常见。 当遇到“WMSYS 重建”的情况,通常是因为WMSYS.WM_CONCAT函数...
在日常数据库操作中,我们经常对数据进行拆分和合并,下面让我们来看看如何... 我们将NAME=A的数据合并,使用Oracle函数WM_CONCAT(),SQL及结果如下: select t.name,to_char(wm_concat(t.code)) from temp
介绍了将多行转为字符串的三种方案,并比较了三种方案的执行效率. 1.sys_connect_by_path + start with ... connect by ... prior + 分析函数 2.自定义Function/SP 3.使用 Oracle 10g 内置函数 wmsys.wm_concat
从Oracle 10g 开始,`wmsys.wm_concat()` 函数提供了更简单的解决方案。这个函数可以自动将多行数据合并为一个以逗号分隔的字符串。尽管这种方法非常直观且易于使用,但它存在一个问题:当查询结果集中有多行数据时...
oracle10g以后,提供了一个函数WMSYS.WM_CONCAT,能很轻松实现该功能。 代码如下:select t.rank, WMSYS.WM_CONCAT(t.Name) TIME From t_menu_item t GROUP BY t.rank; 这样,看着就舒服多了。 这个方法没出来之前,...
达梦数据库不支持GROUP_CONCAT函数,而是使用wm_concat函数来实现字符串聚合。例如: ``` select wm_concat(id) as idstr from person ORDER BY id; ``` 6. FROM_UNIXTIME函数 达梦数据库不支持FROM_UNIXTIME函数,...
5. CAST:类型转换函数,允许将数据从一种Oracle数据类型转换为另一种。 ```sql SELECT CAST(a AS INT) FROM t1; SELECT CAST(a AS NUMBER(8, 4)) FROM t1; ``` 6. INITCAP:将字符串的第一个字母转换为大写,...
### 三、数据类型转换函数 #### 1. to_char `to_char`函数将日期或数字转换为字符串,支持自定义格式化: ```sql SELECT TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS DAY') FROM DUAL; ``` #### 2. 数字格式化 当...
13. 行转列:Oracle 中的 WM_CONCAT 可以合并多行数据,但在 MySQL 中,可以使用 GROUP_CONCAT 实现相同功能。 这些差异表明了 Oracle 和 MySQL 在语法和功能上的区别,对于开发人员和数据库管理员来说,理解这些...
**功能说明**:`WM_CONCAT`函数与`LISTAGG`类似,用于将多个字符串值连接成一个单独的字符串。 **语法结构**: ```sql SELECT id, WM_CONCAT(name) name FROM test_table GROUP BY id; ``` **示例**: ```sql ...