SQL 存储过程

本文介绍了SQL存储过程中的SET NOCOUNT ON/OFF用法,解释了这些信息在客户端应用程序中的作用,并讨论了如何通过设置NOCOUNT来提高程序性能,减少网络流量。建议在存储过程开始时设置SET NOCOUNT ON,退出时设置SET NOCOUNT OFF以优化存储过程。
摘要由CSDN通过智能技术生成
/* 创建表类型.*/
create type XTableType as table(ID int,Names varchar(10));
go
  
/* 创建一个存储过程以表值参数作为输入 */
create Procedure sp_test(@tp1 XTableType readonly)
as
set NoCount on
select *,getdate() from @tp1;
set NoCount off
go

  
/* 声明表值参数变量.*/
declare @tp2 as XTableType;
  
/* 将数据插入表值变量*/
Insert into @tp2(ID,Names)
select 1,'a'
union select 2,'b'
union select 3,'c';
  
/* 将变量传递给存储过程*/
EXEC sp_test @tp2;
go

存储过程之SET NOCOUNT ON/OFF 含义

每次我们在使用查询分析器调试SQL语句的时候,通常会看到一些信息,提醒我们当前有多少个行受到了影响,这是些什么信息?在我们调用的时候这些信息有用吗?是否可以关闭呢? 
答案是这些信息在我们的客户端的应用程序中是没有用的,这些信息是存储过程中的每个语句的DONE_IN_PROC 信息。 
我们可以利用SET NOCOUNT 来控制这些信息,以达到提高程序性能的目的。 
MSDN中帮助如下: 

SET NOCOUNT 
使返回的结果中不包含有关受 Transact-SQL 语句影响的行数的信息。 

语法 
SET NOCOUNT { ON | OFF } 
注释 
当 SET NOCOUNT 为 ON 时,不返回计数(表示受 Transact-SQL 语

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值