1.使用execute来执行字符串
--使用Northwind数据库
declare @sql nvarchar(200)
set @sql='select * from customers'
exec(@sql)
注意:
exec sql和exec(sql)是有区别的.
exec sql是执行存储过程.
exec(sql)是执行sql字符串语句.
2.使用exec sp_executesql来执行字符串
--使用Northwind数据库
declare @sql nvarchar(200)
set @sql='select * from customers'
exec sp_executesql @sql
传递参数:
--使用Northwind数据库 --配置SQL语句 declare @sql nvarchar(200) set @sql='select * from customers where contacttitle=@contacttitle and CompanyName=@CompanyName' --传递SQL参数 declare @contacttitle nvarchar(30) set @contacttitle='owner' --执行SQL字符串 exec sp_executesql @sql,N'@contacttitle nvarchar(30),@CompanyName nvarchar(40)', @contacttitle=@contacttitle,@CompanyName='Bon app'''
现在来看exec sp_executesql的语法:
sp_executesql [@stmt =] stmt [ {, [@params =] N'@parameter_name data_type [,...n]' } {, [@param1 =] 'value1' [,...n] } ]
我们注意到该存储过程的第一个参数是用来设置参数类型的,后面相应的才跟着参数的值.
替换 sp_executesql 中的参数的能力,与使用 EXECUTE 语句执行字符串相比,有下列优点:
1.因为在 sp_executesql 中,Transact-SQL 语句的实际文本在两次执行之间未改变,所以查询优化器应该能将第二次执行中的 Transact-SQL 语句与第一次执行时生成的执行计划匹配。这样,SQL Server 不必编译第二条语句。
2.Transact-SQL 字符串只生成一次。
3.整型参数按其本身格式指定。不需要转换为 Unicode。