sql 里 怎么把一列的值合并成一个字符串

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql 里 怎么把一列的值合并成一个字符串相关的知识,希望对你有一定的参考价值。

1、创建测试表,

create table test_str_concat(id varchar2(20), value varchar2(20));

2、插入测试数据

insert into test_str_concat values(1001, 9001);

insert into test_str_concat values(1002, 9002);

insert into test_str_concat values(1003, 9003);

insert into test_str_concat values(1004, 9004);

insert into test_str_concat values(1005, 9005);

commit;

3、查询表中全量数据,select t.*, rowid from test_str_concat t;

4、编写sql,用listagg函数,把value列的数据,拼成一个字符串;

   select listagg(value,',') with group(order by id) str from test_str_concat t;拼接后结果为:9001,9002,9003,9004,9005

参考技术A

例表 aaa 合并 a 列

 

结果为 123  合并

完整语句如下

declare @id nvarchar(20)

declare @id2 nvarchar(20) 

declare mycursor cursor for select a from aaa  

open mycursor                

fetch next from mycursor into @id  

set @id2=RTRIM(@id)

WHILE @@FETCH_STATUS = 0  

  BEGIN    

     FETCH NEXT FROM mycursor into @id 

     IF @@FETCH_STATUS=0 

     set @id2=@id2+RTRIM(@id)

  END 

print @id2   

close mycursor    

deallocate mycursor

本回答被提问者和网友采纳

oracle语句中如何把一列的值合并为一个值,用逗号隔开?

select Name from User;
我想把Name的值合并成一个值,用逗号隔开。
例如:张三,李四,王五
请问该怎么做?
谢谢。

所有版本的oracle都可以使用wm_concat()函数 。例:select wm_concat(name) as name from user;

但如果是oracle11g,使用listagg() within group()函数 。例:select listagg(name, ‘,’) within group( order by name) as name from user;

使用wm_Concat:

使用ListAgg:

结果:

参考技术A 所有版本的oracle都可以使用select wm_concat(name) as name from user;
但如果是oracle11g,使用select listagg(name, ',') within group( order by name) as name from user;
效率更高,官方也更推荐这种写法。追问

wm开头的函数代表什么意思?
wm本身代表什么含义,是什么的缩写?
oracle的扩展函数的手册啥的叫什么名字?
或者说我上哪里去下载?

追答

在oracle中有一个wmsys用户,这个用户和sys,system等用户一样,是oracle安装的时候就创建的,主要负责oracle日常工作的管理(WM:work manager),wm开头的函数是这个用户下的函数。
oracle的函数介绍在oracle的官方网站上就有,
由于百度知道不让发网址,你可以在百度上搜索listagg,搜索出来的第三项有oracle的网址就是官方的函数介绍的网站,你可以再继续看别的函数的介绍,只不过它的分类是按照功能来分的,而且都是英文的,想看某个函数的话并不太好找。

本回答被提问者采纳
参考技术B select wm_concat(name) name from user;--10g写法
select listagg(name,',') within group (order by name) name from user;--11g写法追问

wm开头的函数代表什么意思?
wm本身代表什么含义,是什么的缩写?
oracle的扩展函数的手册啥的叫什么名字?
或者说我上哪里去下载?

以上是关于sql 里 怎么把一列的值合并成一个字符串的主要内容,如果未能解决你的问题,请参考以下文章

SQL语句:合并列值(将一列的多个值合并成一行)

SQL语句 合并列值 将一列的多个值合并成一行

hive sql语言问题,怎么按一列聚合第二列的多个值合并成1个值,再按这个值group by

SQL 如何把一列的值转换成一行显示

Spark Sql实战--合并数据

Spark Sql实战--合并数据