sqlserver多行转一行字符串(解决for xml path 超过2033截断问题)

1、t-sql:经过测试此方法在数据量较大时候效率特别低。

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文件转换为一个字符串字段。就不会截断。




转载于:https://www.cnblogs.com/strongZZ/p/5942957.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值