db2数据库查询时,wmsys.wm_concat函数如何使用!
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了db2数据库查询时,wmsys.wm_concat函数如何使用!相关的知识,希望对你有一定的参考价值。
参考技术A 多行转一行CREATE TABLE TestTitle (
name VARCHAR(10),
title VARCHAR(20)
);
INSERT INTO TestTitle VALUES ('张三', '程序员');
INSERT INTO TestTitle VALUES ('张三', '系统管理员');
INSERT INTO TestTitle VALUES ('张三', '网络管理员');
INSERT INTO TestTitle VALUES ('李四', '项目经理');
INSERT INTO TestTitle VALUES ('李四', '系统分析员');
Oracle 的时候
使用 WMSYS.WM_CONCAT 处理SQL> SELECT
2 name,
3 WMSYS.WM_CONCAT(title) AS allTitle
4 FROM
5 TestTitle
6 GROUP BY
7 name;
NAME
ALLTITLE
李四
项目经理,系统分析员
张三
程序员,系统管理员,网络管理员
DB2
使用 CTE 处理WITH
t1 (id, name, title) AS
(
SELECT
ROW_NUMBER() OVER(PARTITION BY name ORDER BY title) AS ID,
name,
title
FROM
TestTitle
),
t2 (id, name, title) AS
(
SELECT
t1.id,
t1.name,
CAST(t1.title AS varchar(100)) AS title
FROM
t1
WHERE
t1.id = 1
UNION ALL
SELECT
t1.id,
t2.name,
CAST( t1.title || ',' || t2.title AS varchar(100)) AS title
FROM
t1, t2
WHERE
t1.name = t2.name
AND t1.id = (t2.id + 1)
)
SELECT
name,
title
FROM
t2
WHERE
NOT EXISTS (
SELECT 1
FROM t2 t22
WHERE
t2.name = t22.name
AND t2.id < t22.id
);
NAME TITLE
---------- ---------------------------------------------------------------------
-------------------------------
SQL0347W 递归公共表表达式 "WZQ.T2" 可能包含无限循环。 SQLSTATE=01605
李四 项目经理,系统分析员
张三 网络管理员,系统管理员,程序员
已选择 2 条记录,打印 1 条警告消息。
不知道你DB2 版本:
DB2 9.7 文档中显示, 有一个 LISTAGG 函数可以完成这类的处理.
http://pic.dhe.ibm.com/infocenter/db2luw/v9r7/topic/com.ibm.db2.luw.sql.ref.doc/doc/r0058709.html
orale wmsys.wm_concat()函数
wmsys.wm_concat();
简单创建一张学生表;
CREATE TABLE stu ( s_id VARCHAR(10) not null primary key,--主键 s_name VARCHAR(10) NOT NULL, s_class VARCHAR(10) not null, s_fraction NUMBER(5) NOT NULL );
实现效果:查询没办学生 实现行转列;
select t.s_class,WMSYS.WM_CONCAT(t.s_name) name from stu t GROUP BY t.s_class;
实现效果二:
查询每班 学生姓名及分数实现行转列
select u.s_class,wmsys.wm_concat(u.s_name ||‘(‘||u.s_fraction||‘)‘) from stu u GROUP BY u.s_class;
以上是关于db2数据库查询时,wmsys.wm_concat函数如何使用!的主要内容,如果未能解决你的问题,请参考以下文章
ORACLE 12G 使用函数wmsys.wm_concat问题
Oracle数据库sql 列转字符串行函数WMSYS.WM_CONCAT()
2015.12.24(圣诞节) 解决Oralce数据库将具有相同属性的多行合并为一行的简单方法多年想要wmsys.wm_concat