| 您的当前位置:首页 --> MSSQL教程 |
| SQL Server将一列的多行内容拼接成一行的实现方法 |
| 浏览次数:1246 关键词 ( ) |
|
下面大家先看下示例代码: 示例 昨天遇到一个SQL Server的问题:需要写一个储存过程来处理几个表中的数据,最后问题出在我想将一个表的一个列的多行内容拼接成一行,比如表中有两列数据 :
我想把这个表变成如下格式:
一开始挺头疼的(会了的肯定没有这种感觉,不会那必须是头疼啊(*^__^*) ),从网上找了点资料,算是找到一种比较简单方便的方法吧,现在大体总结一下,供大家共同学习。 原先的表名为Table_A,实现代码如下:
select
类别,
名称 = (
stuff(
(select ',' + 名称 from Table_A where 类别 = A.类别 for xml path('')),
1,
1,
''
)
)
from Table_A as A group by 类别
这里使用了SQL Server 2005版本以后加入的stuff以及for xml path,先说下在上面这句sql中的作用,然后再详细的说明一下这两个的用法。 复制代码 代码如下: for xml path('') 这句是把得到的内容以XML的形式显示。 复制代码 代码如下: stuff((select ',' + ep_name from ep_detail where ep_classes = a.ep_classes for xml path('')), 1, 1, '') 这句是把拼接的内容的第一个“,”去掉 stuff: 1、作用 stuff(param1, startIndex, length, param2) 2、参数 示例
select STUFF('abcdefg',1,0,'1234') --结果为'1234abcdefg'
select STUFF('abcdefg',1,1,'1234') --结果为'1234bcdefg'
select STUFF('abcdefg',2,1,'1234') --结果为'a1234cdefg'
select STUFF('abcdefg',2,2,'1234') --结果为'a1234defg'
for xml path for xml path有的人可能知道有的人可能不知道,其实它就是将查询结果集以XML形式展现,有了它我们可以简化我们的查询语句实现一些以前可能需要借助函数活存储过程来完成的工作。那么以一个实例为主. 假设有个表存放着学生的选课情况(stu_courses):
接下来我们来看应用FOR XML PATH的查询结果语句如下: 复制代码 代码如下: select stu_name,stu_course from stu_courses for xml path; 结果如下:
由此可以看出 FOR XML PATH 可以将查询结果根据行输出成XML各式! |
| 下载次数:13 |
| 下载地址:点击下载 |
| 本资源为程序自动采集,如有侵权请联系我们移除 admin#80vps.com 来信请将#替换为@ |
| 下一条 Sqlserver事务备份和还原的实例代码(必看) 上一条 日常收集整理SqlServer数据库优化经验和注意事项 |