加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQLServer 存储过程 SET NOCOUNT { ON | OFF } 的使用

发布时间:2020-12-12 15:09:50 所属栏目:MsSql教程 来源:网络整理
导读:SQLServer 存储过程 SET NOCOUNT { ON | OFF } 的使用。 使返回的结果中不包含有关受 Transact-SQL 语句影响的行数的信息 语法:SET NOCOUNT { ON | OFF } 默认情况下为 OFF 当 SET NOCOUNT 为 ON 时,不返回计数(表示受Transact-SQL 语句影响的行数)。 当

SQLServer 存储过程 SET NOCOUNT { ON | OFF } 的使用。

使返回的结果中不包含有关受 Transact-SQL 语句影响的行数的信息
语法:SET NOCOUNT { ON | OFF }
默认情况下为 OFF

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

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

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

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

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

注释当SET NOCOUNT 为ON 时,不返回计数(表示受Transact-SQL 语句影响的行数)。当SET NOCOUNT 为OFF 时,返回计数。 ... 结论:我们应该在存储过程的头部加上SET NOCOUNT ON 这样的话,在退出存储过程的时候加上SET NOCOUNT OFF这样的话,以达到优化 ...

SELECT au_lname FROM authors GO USE pubs GO -- SET NOCOUNT to ON and no longer display the count message. SET NOCOUNT ON GO SELECT au_lname FROM authors GO -- Reset SET NOCOUNT to OFF. SET NOCOUNT OFF GO ...

LastName VARCHAR(128) NOT NULL ) SET NOCOUNT OFF SET @Counter = 1 SET @Start = GETDATE() WHILE @Counter <= 150000 BEGIN INSERT #MyTable (FirstName,LastName) VALUES ('Scott','Whigham') SET @Counter = @Counter + 1 ...

语法: SET NOCOUNT { ON | OFF } 阻止在结果中返回可显示受Transact-SQL 语句影响的行数的消息。备注: 当SET NOCOUNT 为ON 时,不返回计数(表示受Transact-SQL 语句影响的行数)。SET NOCOUNT 设置是在执行或运行时设置,而不是在分析时设置。 ...

时是为服务器与sp _ < " 用户选项",512 configure > 配置SET NOCOUNT ON 复位@ ROWCOUNT 值@ ROWCOUNT 值重置。 下列语句是从事务处理SQL 帮助有关SETNOCOUNT: Turns off the message returned at the end of each statement that states how many rows ...

CREATE?? PROC sp_Flow_DeleteFlow
@FlowID int
/*

============================================================
功能: 删除流程
参数:
@FlowID int??? : 流程ID

============================================================

*/
AS
--没有相关的流程才能删除此流程
SET NOCOUNT ON

IF EXISTS(SELECT 1 FROM WF_flow WHERE flow_id = @FlowID)
BEGIN
?? IF NOT EXISTS(SELECT 1 FROM WF_flow_document WHERE flow_id = @flowid)
?? BEGIN
??? --删除实体
??? DELETE FROM WF_flow
???? WHERE flow_id = @FlowID
??? --删除流程步骤
??? DELETE FROM WF_Flow_Step
???? WHERE flow_id =@FlowID
??? --删除绑定
??? DELETE FROM WF_flow_member_bind
???? WHERE flow_id = @flowid
??
??? PRINT '流程删除成功'
??? RETURN 0
?? END
?? ELSE
?? BEGIN
??? PRINT '流程删除失败,此流程正在被一个文档使用!'
??? RETURN -1
?? END
END
ELSE
BEGIN
??? PRINT '流程不存在!'
??? RETURN -2
END

SET NOCOUNT OFFGO

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读