您的位置:首页 > 数据库

SQL SERVER存储过程是否返回受影响的行,SET NOCOUNT ON|OFF

2010-07-05 14:04 441 查看
SET NOCOUNT (Transact-SQL)

阻止在结果集中返回可显示受 Transact-SQL 语句或存储过程影响的行计数的消息。

Transact-SQL 语法约定

语法

--------------------------------------------------------------------------------

复制
SET NOCOUNT { ON | OFF }
备注

--------------------------------------------------------------------------------

当 SET NOCOUNT 为 ON 时,不返回计数。当 SET NOCOUNT 为 OFF 时,返回计数。

即使当 SET NOCOUNT 为 ON 时,也更新 @@ROWCOUNT 函数。

当 SET NOCOUNT 为 ON 时,将不向客户端发送存储过程中每个语句的 DONE_IN_PROC 消息。如果存储过程中包含一些并不返回许多实际数据的语句,网络通信流量便会大量减少,因此,将 SET NOCOUNT 设置为 ON 可显著提高性能。

SET NOCOUNT 指定的设置是在执行或运行时生效,而不是在分析时生效。

权限

--------------------------------------------------------------------------------

要求具有 public 角色的成员身份。

示例

--------------------------------------------------------------------------------

以下示例将禁止显示受影响的行数的消息。

复制
USE AdventureWorks;GOSET NOCOUNT OFF;GO-- Display the count message.SELECT TOP(5)LastNameFROM Person.ContactWHERE LastName LIKE 'A%';GO-- SET NOCOUNT to ON to no longer display the count message.SET NOCOUNT ON;GOSELECT TOP(5) LastNameFROM Person.ContactWHERE LastName LIKE 'A%';GO-- Reset SET NOCOUNT to OFFSET NOCOUNT OFF;GO

http://msdn.microsoft.com/zh-cn/library/ms189837(v=SQL.90).aspx
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: