2、for xml path:此方法效率可以但是需要注意利用stuff函数将生成的xml文件转换为字符串,否则用sqldatereader或者SqlDataAdapter读取数据只能读取2033个字符。
例如:有如下test表有
数据
Id Name
1 a
2 b
3 c
4 d
当使用:SELECT
','+Id
FROM
dbo.Test
FOR
XML
PATH
('')); //这样读取的数据虽然是1,2,3,4,但是仍然是xml格式,所以当数据超过2033时候,用sqldatereader或者sqldateadapter读取数据会截断xml文件。
此时要:SELECT
STUFF((
SELECT
','+Id
FROM
dbo.Test
FOR
XML
PATH
('')),1,1,'');//利用stuff函数将xml文件转换为一个字符串字段。就不会截断。