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 语句影响的行数)。当 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 权限默认授予所有用户。 

结论:我们应该在存储过程的头部加上SET NOCOUNT ON 这样的话,在退出存储过程的时候加上 SET NOCOUNT OFF这样的话,以达到优化存储过程的目的。

 

 

 

if (exists(select * from  sys.objects where name='GetUser'))
    drop proc GetUser
go 
create proc GetUser
    @id int output,
    @name varchar(20) out
as 
begin 
    select @id=Id,@name=Name from UserInfo where Id=@id
end

go 
declare 
@name varchar(20),
@id int;
set @id=3;
exec dbo.GetUser @id,@name out;
select @id,@name;
print Cast(@id as varchar(10))+'-'+@name;

分页获取数据的存储过程

if (exists(select * from  sys.objects where name='GetUserByPage'))
    drop proc GetUserByPage
go 
create proc GetUserByPage
    @pageIndex int,
    @pageSize int
as 
declare 
@startIndex int,
@endIndex int;
set @startIndex =  (@pageIndex-1)*@pageSize+1;
set @endIndex = @startIndex + @pageSize -1 ;
begin 
    select Id,Name from 
    (
        select *,row_number()over (order by Id)as number from UserInfo  
    )t where t.number>=@startIndex and t.number<=@endIndex
end

go 
exec dbo.GetUserByPage 2,4;

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值