赞
踩
可以使用SQL Server中的STUFF和FOR XML PATH函数将查询结果合并为一个字段并用逗号分隔。具体步骤如下:
```sql
SELECT STUFF((SELECT ',' + name FROM user_info FOR XML PATH('')), 1, 1, '') AS merged_names
```
其中,`FOR XML PATH('')`表示将查询结果按照空字符串分隔,`STUFF`函数用于删除第一个逗号并插入合适的分隔符。最终的结果将会是一个包含所有name的逗号分隔的字符串。
可以使用SQL Server的PIVOT函数实现行转列。具体步骤如下:
1. 使用SELECT语句查询出需要转换的数据,例如:
```sql
SELECT id, category, value
FROM my_table
```
2. 使用PIVOT函数将行转列,例如:
```sql
SELECT id, [Category_1], [Category_2], [Category_3]
FROM (
SELECT id, category, value
FROM my_table
) AS SourceTable
PIVOT (
MAX(value)
FOR category IN ([Category_1], [Category_2], [Category_3])
) AS PivotTable
```
其中,MAX(value)表示当多个行具有相同的id和category时,使用最大的value作为结果。
3. 如果需要动态生成列名,可以使用动态SQL语句,例如:
```sql
DECLARE @cols AS NVARCHAR(MAX), @query AS NVARCHAR(MAX);
SET @cols = STUFF((SELECT distinct ',' + QUOTENAME(category) FROM my_table FOR XML PATH(''), TYPE).value('.', 'NVARCHAR(MAX)'), 1, 1, '');
SET @query = 'SELECT id, ' + @cols + ' FROM (SELECT id, category, value FROM my_table) AS SourceTable PIVOT (MAX(value) FOR category IN (' + @cols + ')) AS PivotTable';
EXECUTE (@query);
```
其中,STUFF函数用于删除第一个逗号,QUOTENAME函数用于将列名转换为合法的SQL标识符。
赞
踩
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。