入门客AI创业平台(我带你入门,你带我飞行)
博文笔记

SQL执行字符串

创建时间:2013-02-27 投稿人: 浏览次数:856

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。

声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。
  • 上一篇:没有了
  • 下一篇:没有了
未上传头像