首页 > 数据库技术 > 详细

动态SQL字符长度超过8000

时间:2015-06-04 15:33:30      阅读:299      评论:0      收藏:0      [点我收藏+]

动态SQL字符长度超过8000,我记得SQL SERVER 2008中用SP_EXECUTESQL打破了这个限制。

 

平常用动态SQL,可能都会用EXEC(),但是有限制,就是8000字符串长度。自从SQL SERVER 2005起,在 INSIDE SQLSERVER 2005 T-SQL PROGRAMMING中提到,使用SP_EXECUTESQL()和NVARCHAR(MAX)可以超越8000个字符的限制。因为 SP_EXECUTESQL()必须使用NVARCHAR,NCHAR,NTEXT作为参数,所以SP_EXECUTESQL()的最长字符限制就是 4000。

 

我们看一个NVARCHAR(4000)的例子:

 

技术分享

 

 

如何打破这个限制,我们再看(将SQL字符变量类型设置为NVARCHAR(MAX)):

 

技术分享

 

可以看到,成功执行了SQL字符长度为9999的动态SQL。。

 

看一个SQL字符超过100000的例子:

 

技术分享

 

 

字符串长度巨大,我只能将结果保存到RPT文件,可惜的是,我的机器(2.5内存+32位WIN2003)还是不能显示,肯定是资源不够用

动态SQL字符长度超过8000

原文:http://www.cnblogs.com/aflyfly/p/4551592.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!