SQLServer 中多行数据合并成一行数据(一个字段)

需求:有四行数据,如下:

  1.苹果
  2.橘子
  3.桃子
  4.波罗

  合并成一个字段:苹果,橘子,桃子,波罗;

  需求明确之后,先弄点测试数据,上代码:

  

--创建一个临时表
Create table #temp
(
    testName varchar(20)
)

--写入测试数据
INSERT INTO #temp(testName) values(‘苹果‘);
INSERT INTO #temp(testName) values(‘橘子‘);
INSERT INTO #temp(testName) values(‘桃子‘);
INSERT INTO #temp(testName) values(‘波罗‘);

--查询写入的数据
SELECT * FROM #temp
--DELETE #temp

演示数据填充好了之后,我们可以有以下几种方法实现需求:

一:

DECLARE @listStr VARCHAR(MAX);
SELECT @listStr = ISNULL(@listStr+‘,‘,‘‘)+ testName
FROM #temp
SELECT @listStr

在上面的脚本代码中,使用了ISNULL函数,也可以使用Coalesce函数,这两个函数都有空值情况下处理字符串的功能,更深层次的区别参考这里

那么问题来了,我为什么要使用ISNull或者Coalesce 函数呢?这是因为所有的数据行中如果不排除有空值的可能,最好加上空值判断的处理,因为在SQLSERVER中,如果需要进行字符串拼接,遇到空值的话是无法拼接的。

二:使用for xml path(‘‘) 和stuff ;

    SELECT ‘,‘ + testName
    FROM #temp for xml path(‘‘)

三:使用字符串函数 STRING_AGG,这个函数是SQLSERVER 2017 之后才有的。

SELECT STRING_AGG(ISNULL(testName,‘N/A‘), ‘,‘)
FROM #temp

查询结果为:苹果,橘子,桃子,N/A,波罗

原文地址:https://www.cnblogs.com/bdqczhl/p/11665818.html

时间: 2024-08-26 05:37:18

SQLServer 中多行数据合并成一行数据(一个字段)的相关文章

mysql中将多行数据合并成一行数据

一个字段可能对应多条数据,用mysql实现将多行数据合并成一行数据 例如:一个活动id(activeId)对应多个模块名(modelName),按照一般的sql语句: 1 SELECT am.activeId,m.modelName 2 FROM activemodel am 3 JOIN model m 4 ON am.modelId = m.modelId 5 ORDER BY am.activeId 查询出的列表为图1所示: 图1 修改过后的sql语句,查询后如图2所示: 1 SELECT

oracle查询多行数据合并成一行数据

如果是oracle 10g以上 一个wm_concat函数就可以解决. 如果是oracle 9i以下就有点麻烦了. 表结构如下: NAME Null Type ------------------------ --------- ----- N_SEC_CODE NOT NULL CHAR(6) C_RESEARCHER_CODE NOT NULL VARCHAR2(20) 此表保存了“股票”与“研究员”的对应关系数据,一般而言,对于同一只股票而言,可能有多个研究员 对其进行跟踪研究.所以目前遇

SQL 将一条记录中多个字段的值拼接为一个字段 && 将多行数据合并成一行,并且拼接CONVERT() 、for xml path的使用

接着上篇文章的订单表(商品编号,价格设置时间id(类似于创建时间,创建时间约早,则act_id越小) ,价格的时间段,商品价格) 一.将一条记录中多个字段的值拼接为一个字段 现要求将两个时间段合并为一个字段,应该如何做呢? 先来看下理想的结果: 查询出的时间段合并到一起了: 代码如下,将查询的字段用+'你想要的符号' + 拼接即可 select item,act_id,loc_id,convert(varchar(100),start_date,20)+ '-' +convert(varchar

ORACLE 多列合并成一行数据 WM_CONCAT函数以及REPLACE

SELECT ( --SELECT REPLACE(SBPT.PARKSTIME||'~'||SBPT.PARKETIME,',') REPLACE也可以 SELECT WM_CONCAT(SBPT.PARKSTIME||'~'||SBPT.PARKETIME) SAREE FROM SYS_BERTHANDTYPE SBT LEFT JOIN SYS_BERTHTYPEPARKTIME SBPT ON SBT.BERTHTYPEID = SBPT.BERTHTYPEID WHERE BERTH

SQL SERVER将多行数据合并成一行(转)

1)比如表中有三列数据: 2)执行如下查询: 1 SELECT [USER_NAME], [USER_ACCOUNT] 2 , [ROLE_NAME] = stuff(( 3 SELECT ',' + [ROLE_NAME] 4 FROM [WAP_WORKSHEET].[dbo].[userTest] 5 WHERE [USER_ACCOUNT] = a.[USER_ACCOUNT] 6 FOR XML path('') 7 ), 1, 1, '') 8 FROM [WAP_WORKSHEET

sql查询 ,多行数据合并成一行,并且显示合并后某一列的值拼接结果

select  [value] = stuff((select ','+modmb003  from modmb detail where modmb=18 for xml path('')), 1, 1, '') 其中stuff的作用是:删除指定长度的字符,并在指定的起点处插入另一组字符 语法:STUFF ( character_expression , start , length ,character_expression ) 列:SELECT STUFF('abcdef', 2, 3,

hive concat_w实现将多行记录合并成一行

建表如下: # 创建商品与促销活动的映射表 hive -e "set mapred.job.queue.name=pms; set hive.exec.reducers.max=32; set mapred.reduce.tasks=32; drop table if exists product_promotion; create table product_promotion(product_id bigint, promotion_id String); insert into table

MySQL多行结果合并成一行,GROUP_CONCAT

测试数据表 以product_id;分组,把name字段的值打印在一行,逗号分隔(默认) SELECT id,GROUP_CONCAT(name) FROM test_brand GROUP BY product_id; 以id分组,把name字段的值打印在一行,分号分隔 SELECT id,GROUP_CONCAT(name SEPARATOR ';') FROM `test_brand` GROUP BY product_id;

oracle 聚合函数 LISTAGG ,将多行结果合并成一行

LISTAGG( to_char(Item_Category_Name), ',') WITHIN GROUP(ORDER BY Item_Category_Name)  -- 将 Item_Category_Name 列的内容以", "进行分割合并.排序: to_char(Item_Category_Name) --  to_char(列名)  解决使用聚合函数 LISTAGG 进行查询后,对查询结果乱码问题进行转码处理: 原文地址:https://www.cnblogs.com/z