• sql执行字符串


    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。 

  • 相关阅读:
    每日一题力扣222 完全二叉树节点的个数
    236 二叉树的最近公共祖先
    每日一题力扣122
    每日一题力扣 100 相同的树
    每日一题力扣617 合并二叉树
    每日一题力扣226
    每日一题力扣101 对称子树
    腾讯 qq 与 360 打架, 腾讯qq 无理
    决定把 blog 从 csdn.net 迁移到 cnblogs.com
    发现 google 网站管理员工具中给出的 javascript 代码是错误的
  • 原文地址:https://www.cnblogs.com/xlhblogs/p/2888425.html
Copyright © 2020-2023  润新知