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


参考技术B 不会这个啊

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问题

orale wmsys.wm_concat()函数

wmsys.wm_concat()函数的使用

Oracle数据库sql 列转字符串行函数WMSYS.WM_CONCAT()

行列转换_wmsys.wm_concat

2015.12.24(圣诞节) 解决Oralce数据库将具有相同属性的多行合并为一行的简单方法多年想要wmsys.wm_concat