sql server 2000中变量类型varchar(8000)的问题

fancy0109 2011-10-12 05:43:00
60个 a
declare @sql varchar(8000)
set @sql = ''
select @sql = @sql
+ 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa' + char(13)
+ name + char(13)
+ 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa' + char(13)
from syscolumns where id = object_id('sysobjects')
print(@sql)
select len(@sql)


为什么只有4000,select @var = @var + colName from tbName 的形式不能用varchar(8000)吗?
用这种模式,@sql 长度到4000后,再用
set @sql = @sql + 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'

就可以超过4000了,请高手指点一下,谢谢了。
...全文
164 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
fancy0109 2011-10-12
  • 打赏
  • 举报
回复
谢谢 大版 和 小三,按照设置了,但是没有得到应有效果,按照xiangaylian(大驴)的调整了,正解,谢谢大家的帮助,祝大家身体健康、工作生活开心。
saizhang 2011-10-12
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 xiangaylian 的回复:]

SQL code

declare @sql varchar(8000),@co int
set @sql = ''
set @co = 1
while @co <= 99
begin
set @sql = @sql + 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa……
[/Quote]
+1
saizhang 2011-10-12
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 acherat 的回复:]

查询出的是8000,但显示的是4000,可以设置显示的字符,按大版说的设置。
[/Quote]
+1
saizhang 2011-10-12
  • 打赏
  • 举报
回复
顶----
xiangaylian 2011-10-12
  • 打赏
  • 举报
回复
更正一下,是@sql + cast(name as varchar(50))
不加长度会被截断为长度1的!
我是这么想的,有问题请前辈指正!
xiangaylian 2011-10-12
  • 打赏
  • 举报
回复
更正一下,是@sql + cast(name as varchar(50))
不加长度的话,会被截断为varchar(1)的!
Test:

declare @a varchar
set @a = 'aaa'
print @a
bancxc 2011-10-12
  • 打赏
  • 举报
回复
难道真的强制转换成了nvarchar 兲
bancxc 2011-10-12
  • 打赏
  • 举报
回复
神马意思 版大
xiangaylian 2011-10-12
  • 打赏
  • 举报
回复

declare @sql varchar(8000),@co int
set @sql = ''
set @co = 1
while @co <= 99
begin
set @sql = @sql + 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
set @co = @co + 1
end
print len(@sql)
set @sql = @sql + char(13)
print len(@sql)
--随便加一列
select @sql = @sql + name from syscolumns where name = 'rowsetid' and id = 4
print len(@sql)

/*
结果:
8000
8000
4000
*/

以上结果说明:
在@sql + char(13)的时候正常,@sql + name 的时候变成4000了
其实我也遇到过这种情况,在一个varchar与nvarchar拼接的时候,最终长度怎么都超不过4000,因为nvarchar的最大长度就是4000,我觉得是被强制转化成nvarchar了,你拼接@sql + name的时候改成
@sql + cast(name as varchar)就不会了。
AcHerat 2011-10-12
  • 打赏
  • 举报
回复
查询出的是8000,但显示的是4000,可以设置显示的字符,按大版说的设置。
中国风 2011-10-12
  • 打赏
  • 举报
回复
以文字顯示結果
每行最大字元靈數,在這里設置
中国风 2011-10-12
  • 打赏
  • 举报
回复
在查詢分析器—工具—選項里(設置顯示字符數)

27,580

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧