还是比较实用的功能,自己也记录一下。转自http://www.cnblogs.com/changbluesky/archive/2010/06/10/1753036.html
SQL中的叠加(小提示):有如下的需求,用SQL实现把结果集合转换为字符串.
如下:
可以有至少如下三种方法来做转换:
1. 在.NET中通常的做法是先取出结果集放在DataTable中,再利用foreach循环取出每个字段串联起来. 亦如这样,在SQL中也有相同的做法,就是用游标(CURSOR)做循环,示例代码如下:
Cursor
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->declare @mytable table
(
Col1 varchar(10)
)
insert into @mytable values
('AA'),
('BB'),
('CC')
select SUBSTRING(@Colstring,2,LEN(@Colstring)-1) as Colstring
declare mytype cursor local for
select Col1 from @mytable
open mytype
fetch next from mytype into @Col1
while @@FETCH_STATUS=0
begin
set @Colstring+=','+@Col1
fetch next from mytype into @Col1
end
deallocate mytypedeclare @Colstring varchar(50)=''
declare @Col1 varchar(10)
转换之后的字符串:
CURSOR在SQL中的效率很差,当数据量比较大时(>1 Million)会严重影响性能,不建议使用.
2. SQL查询中直接赋值,这种方式CODE比较简捷.
代码
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->declare @mytable table
(
Col1 varchar(10)
)
insert into @mytable values
('AA'),
('BB'),
('CC')
declare @Colstring varchar(50)
select @Colstring = isnull(@Colstring + ',' , '' ) + isnull( Col1 , '' )
from @mytable
select @Colstring as Colstring
运行结果:
3. FOR XML PATH
首先转换为XML的数据库类型.
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->declare @mytable table
(
Col1 varchar(10)
)
insert into @mytable values
('AA'),
('BB'),
('CC')
SELECT ','+Col1 --No alias
FROM @mytable
ORDER BY Col1
FOR XML PATH('TYPE')
可以看到输入结果是XML类型的,TYPE为节点
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--><TYPE>,AA</TYPE>
<TYPE>,BB</TYPE>
<TYPE>,CC</TYPE>
假如没有TYPE节点,就会接近想要的结果,修改CODE如下:
代码
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->declare @mytable table
(
Col1 varchar(10)
)
insert into @mytable values
('AA'),
('BB'),
('CC')
SELECT ','+Col1 --No alias
FROM @mytable
ORDER BY Col1
FOR XML PATH('')
太好了,只需要把前置逗号(,)取消就OK了,接续修改CODE:
FOR XML PATH
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->declare @mytable table
(
Col1 varchar(10)
)
insert into @mytable values
('AA'),
('BB'),
('CC')
select STUFF((
SELECT ','+Col1 --No alias
FROM @mytable
ORDER BY Col1
FOR XML PATH('')) ,1,1,space(0)) as Colstring
得到需求的结果:
扩展如下:
代码
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->declare @mytable table
(
id int,
potype varchar(10)
)
insert into @mytable values (1,'A>A')
insert into @mytable values (1,'B&B')
insert into @mytable values (1,'C<C')
SELECT p1.id,
STUFF ( ( SELECT ','+potype
FROM @mytable p2
WHERE p2.id = p1.id
ORDER BY potype
FOR XML PATH(''),TYPE
).value('.','VARCHAR(MAX)') , 1,1,SPACE(0)) AS Concat_Values
FROM @mytable p1
GROUP BY p1.id ;
代码
<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />-->DECLARE @mytable
TABLE (
id INTEGER NOT NULL,
potype VARCHAR(10) NOT NULL
);
INSERT @mytable VALUES (1,'A>A');
INSERT @mytable VALUES (1,'B&B');
INSERT @mytable VALUES (1,'C<C');
SELECT P1.id,
csv = STUFF
(
(
SELECT ',' + P2.potype
FROM @mytable P2
WHERE P2.id = P1.id
ORDER BY P2.potype ASC
FOR XML PATH(''), TYPE
).value('./text()[1]', 'VARCHAR(MAX)')
, 1, 1, SPACE(0)
)
FROM @mytable P1
GROUP BY P1.id;
推荐采用第二种,或是第三种方法.
分享到:
相关推荐
sql-varbinary转换成字符串,主要是将SQL中的二进制转换成字符串显示。
sql中将数字转换为字符串—STR().doc
sql server 2008 将一列值转换成一个字符串
SQL的datetime类型数据转换为字符串格式大全 2007-10-10 11:11:43 2007/10/10 SELECT convert(char(20),getdate(),120) as TIME_1,convert(char(20),getdate(),111) as TIME_2 将字符串20100426103059转换为...
您可能感兴趣的文章:sql语句中如何将datetime格式的日期转换为yy-mm-dd格式将WMI中的DateTime类型转换成VBS时间的函数代码LINQ字符串向datetime 转换时失败的处理方法Sql中将datetime转换成字符串的
将sql sqlser 日期类型转化成各种格式的字符串。
之所以写这个,是因为发现SQL注入和XSS中经常利用十六进制表示的字符串,比如 SELECT CONCAT(0x68656c6c6f); 得到的是hello <!DOCTYPE html> <html> <head> <title>Hex-Char Bi-Converter&...
SQL的datetime类型数据转换为字符串格式大全.doc
包含各种类型的数据转换成字符串输出,讲解详细使用简单。
SQLServer逗号分隔的字符串转换成表
sqlserver中常用函数----字符串函数---- ASCII() --函数返回字符表达式最左端字符的ASCII 码值 CHAR() --函数用于将ASCII 码转换为字符 --如果没有输入0 ~ 255 之间的ASCII 码值CHAR 函数会返回一个NULL 值 ...
oracle通过sql实现字符串转数字oracle函数,可用于字符串的最终排序
ADO助手---一个获取ADO连接字符串,测试SQL命令的辅助软件 2010-09-06 +初始版本发布 ADO助手---一个获取ADO连接字符串,测试SQL命令的辅助软件 2010-09-06 +初始版本发布 2011-11-09 -修复有时候用DataGrid...
sql 实例 批量转换 字符串转换日期
SQL截取以逗号分隔的字符串SQL截取以逗号分隔的字符串SQL截取以逗号分隔的字符串SQL截取以逗号分隔的字符串
sqlserver中根据某个字符切割字符串函数,比如根据逗号切割字符串,结果返回的是一个表值函数,这个函数返回结果字段包含Id和Value,Id为序号,Value为切割后的值
SQL Server中,在“整型数字”和“字符串表示的十六进制数字”之间进行转换的函数: IntToHex 数字转十六进制 HexToInt 十六进制转数字
SQL SERVER 关于日期函数(字符转日期,日期转字符串)
SQL-SERVER-2000数据库-转换为ACCESS数据库.doc
、指定字符串分割字符串、指定字符串位置获取字符串、过滤SQL中非法字符、检查SQL语句中是否有非法关键字、随机字符串生成、唯一字符串生成、随机数字生成、唯一数字串生成、去除HTML标签、判断是否整型、判断是否...