SQLServer中如何实现行合并(sqlserver合并行)


随着计算机技术的发展,微软sql server数据库技术已经成为大多数企业日常数据库管理系统的首选,有时会遇到行合并的需求,本文将介绍sql server中如何实现行合并。

1、 使用空格字符分隔。在空格字符分隔符后使用nchar或nvarchar拼接。代码如下:

“`SQL

SELECT cl.CustomerID,

STUFF(

(SELECT ‘ ‘ + c2.Country

FROM [SalesLT].[CustomerAddress] c2

WHERE c2.CustomerID = cl.CustomerID

FOR XML PATH (”)

), 1, 1, ”

) AS Country

FROM [SalesLT].[CustomerAddress] cl

GROUP BY cl.CustomerID

以上代码会把同一CustomerID的Country列拼接起来,用空格分隔,其结果如下:
| CustomerID | Country |
| ---------- | ------- |
| 1 | USA Canada |
|2 | Australia |
2、使用其他分隔符。上述代码中的,“FOR XML PATH”路径允许您指定另一分隔符来代替空格。例如,使用“,”分隔行,这样它会生成形如“ USA,Canada ”的格式。代码如下:

```SQL
SELECT cl.CustomerID,
STUFF(
(SELECT ',' + c2.Country
FROM [SalesLT].[CustomerAddress] c2
WHERE c2.CustomerID = cl.CustomerID
FOR XML PATH ('')
), 1, 1, ''
) AS Country
FROM [SalesLT].[CustomerAddress] cl
GROUP BY cl.CustomerID

结果:

| CustomerID | Country |

| ———- | ——- |

| 1 | USA,Canada |

|2 | Australia |

3、使用FOR XML PATH()函数。使用FOR XML PATH()函数可以使用标签来标记多行数据。例如,将以下代码放入查询中:

“`SQL

SELECT cl.CustomerID,

STUFF(

(SELECT ” + c2.Country + ” as [text()]

FROM [SalesLT].[CustomerAddress] c2

WHERE c2.CustomerID = cl.CustomerID

FOR XML PATH (”)

), 1, 0, ”

) AS Country

FROM [SalesLT].[CustomerAddress] cl

GROUP BY cl.CustomerID

运行查询产生以下结果:
| CustomerID | Country |
| ---------- | ------- |
| 1 | USACanada |
|2 | Australia |
上述代码就是sql server 中实现行合并的方法,它非常灵活,可以在数据库中实现行合并,增加了数据处理的灵活性。

总之,sql server 中实现行合并的方法有很多种,具体实现时可以选择不同的方法,根据需求灵活选择,这样可以更好的满足实际应用的需求。