SET NOCOUNT ON/OFF语句用法介绍

发布时间:2019-09-26编辑:脚本学堂
有关sql数据库中SET NOCOUNT ON/OFF语句的用法,当 SET NOCOUNT 为 ON 时,不返回计数,当 SET NOCOUNT 为 OFF 时,返回计数,不了解的朋友可以参考下文中内容。

SET NOCOUNT ON/OFF语句用法

说明:
当 SET NOCOUNT 为 ON 时,不返回计数(表示受Transact-SQL 语句影响的行数)。
当 SET NOCOUNT 为 OFF 时,返回计数(默认为OFF)。

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

当 SET NOCOUNT 为 ON 时,将不给客户端发送存储过程中的每个语句的 DONE_IN_PROC 信息。当使用 Microsoft? SQL Server? 提供的实用工具执行查询时,在 Transact-SQL 语句(如 SELECT、INSERT、UPDATE 和 DELETE)结束时将不会在查询结果中显示"nn  行受影响"。

如果存储过程中包含的一些语句并不返回许多实际的数据,则该设置由于大量减少了网络流量,因此可显著提高性能。

SET NOCOUNT 设置是在执行或运行时设置,而不是在分析时设置。

注释当SET NOCOUNT 为ON 时,不返回计数(表示受Transact-SQL 语句影响的行数)。当SET NOCOUNT 为OFF 时,返回计数。

小结:
建议在存储过程的头部加上SET NOCOUNT ON,在退出存储过程时加上SET NOCOUNT OFF,以达到优化。

据小编观察,sql server 2005之后的存储过程中,默认是加上了 SET NOCOUNT ON的。