一个print @@rowcount 奇怪现象

dssw 2006-06-13 06:30:16
--死循环语句
select top 1 * from sysobjects
while @@rowcount > 0
begin
select top 1 * from sysobjects
end
--但是,如果加上 print @@rowcount 就不死循环.
select top 1 * from sysobjects
while @@rowcount > 0
begin
select top 1 * from sysobjects
print @@rowcount
end

请高手帮我分析分析.
...全文
185 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
dssw 2006-06-14
  • 打赏
  • 举报
回复
为了说明问题啊。
没有实际作用。
Reeezak 2006-06-13
  • 打赏
  • 举报
回复
楼上已经说了原因了

不过我不明白lz为什么要这样写
select top 1 * from sysobjects
while @@rowcount > 0
begin
select top 1 * from sysobjects
--print @@rowcount 假设不要这个
end

sysobjects 是肯定有东西的啊,所以无论如何,你的@@rowcount 都会大于1
那么这样的代码还有什么意义呢?
xeqtr1982 2006-06-13
  • 打赏
  • 举报
回复
print返回的是一个消息,而非一条记录。
xeqtr1982 2006-06-13
  • 打赏
  • 举报
回复
在这一点上select 与print不同

比较一下下面的结果的不同

select 1
select @@rowcount
--
print 1
select @@rowcount
xeqtr1982 2006-06-13
  • 打赏
  • 举报
回复
print 1
select @@rowcount

--print的影响行数为0

select top 1 * from sysobjects
while @@rowcount > 0
begin
select top 1 * from sysobjects
print @@rowcount
end

循环中print @@rowcount的影响行数为0所以循环停止

34,873

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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