码迷,mamicode.com
首页 > 数据库 > 详细

sp_executesql 使用

时间:2016-06-16 19:55:13      阅读:164      评论:0      收藏:0      [点我收藏+]

标签:

sp_executesql 比 之前的exec @sql 区别在可以实现参数的传入传出

declare @sql nvarchar(2000) 
declare @pid varchar(20) 
set @pid=‘001‘ 
set @sql=‘select count(1) from Sale (nolock) where pid=‘ + @pid 
exec @sql 

在传统的 exec 是无法将Count(*)传出到外面 的

 

 

但是如果用 sp_executesql 则很简单

declare @sql nvarchar(2000) 

declare @saleCount int 
declare @pid varchar(20) 
set @pid=‘001‘ 
set @sql=‘select @count=count(1) from Sale  (nolock) where pid=@pid‘ 
exec sp_executesql @sql, N‘@count int out,@pid varchar(20)‘, @saleCount out ,@id 
print @saleCount 

 

 

 

set statistics time on
Go

declare @sql nvarchar(2000)

declare @recordCount int
declare @OpType int
set @OpType= 300305
set @sql=‘select @Count=count(1) from UserAmountLog (nolock) where OpType=@type‘
exec sp_executesql @sql, N‘@Count int out,@type int‘, @recordCount out ,@OpType
print @recordCount

 

用exec,由于每次传入的参数值不一样,所以每次生成的@sql就不一样,这样每执行一次Sql 就必须重新将要执行的动态Sql重新编译一次 
但是sp_executesql则不一样,由于将数值参数化,要执行的动态Sql永远不会变化,只是传入的参数的值在变化,那每次执行的时候就秒用重新编译,速度自然快多了 ! 

sp_executesql 使用

标签:

原文地址:http://www.cnblogs.com/zhshlimi/p/5591754.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!