sp_executesql,sql2005中引入的新的系统存储过程,也是用来处理动态sql的,

如: exec sp_executesql @sql, N'@item_name nvarchar(100) out,@id nvarchar(20)',   @item_name out,@id

参数说明:

@sql为拼成的动态sql

N'@item_name nvarchar(100) out,@id nvarchar(20)' 为拼成的动态sql内的参数列表

@name out,@id 为动态sql内参数列表提供值的外部参数列表

执行动态SQL时,Exec与 sp_executesql 之间的区别:

1、它们之间最大的区别是嵌入式的参数,如下面一个语句

declare @sql nvarchar(2000)

declare @id varchar(20)

set @id='888' set @sql='select item_name from t_item where id=' + @id

exec @sql

想把得到的item_name传出来,用传统的exec是不好办到的,

但是用sp_executesql则很容易就办到了:

declare @sql nvarchar(2000)

declare @item_name nvarchar(100)

declare @id nvarchar(20)

set @id='888'

set @sql='select @item_name=item_name  from t_item where id=@id'

exec sp_executesql

@sql,

N'@item_name nvarchar(100) out,@id nvarchar(20)',

@item_name out,@id

2、性能  可以看到,如果用exec,由于每次传入的@id不一样,所以每次生成的@sql就不一样,这样每执行一次Sql2005就必须重新将要执行的动态Sql重新编译一次,  但是sp_executesql则不一样,由于将数值参数化,要执行的动态Sql永远不会变化,只是传入的参数的值在变化,那每次执行的时候就不用重新编译,更节约时间!

另外,特别要注意的是:

1、sp_executesql要求动态Sql和动态Sql参数列表必须是Nvarchar

2、动态Sql的参数列表与外部提供值的参数列表顺序必需一致,

如: N'@item_name nvarchar(100) out,@id nvarchar(20)', @item_name out,@id

@item_name 对应@item_name ,@id对应@id

如果不一致,必须显式标明,

如: N'@item_name nvarchar(100) out,@id nvarchar(20)', @id=@id, @item_name =@item_name out

3、动态SQl的参数列表与外部提供参数的参数列表中的参数名可以同名。

最新文章

  1. JavaScript中map函数和filter的简单举例(转)
  2. underscore源码阅读记录(二)
  3. JVM执行引擎总结(读《深入理解JVM》) 早期编译优化 DCE for java
  4. 导出word使用模版
  5. SharePoint 2013 Service 状态无法启动,显示“启动中(Starting)”
  6. Asp.Net缓存(1)
  7. spring-data-redis工程
  8. Ubuntu通过源代码编译安装Octave 4.0
  9. hdu1500 (排序+单调队列优化 )
  10. SQL server 2005 PIVOT运算符的使用
  11. 【转】Android中保持Service的存活
  12. Open SuSE虚拟机分辨率不能自适应的解决办法
  13. react-native-table-component, react-native 表格
  14. 加减乘除工具类BigDecimalUtil
  15. Problem A 你会定义类吗?
  16. spring中基于aop使用ehcache
  17. Java多线程(三) —— 线程并发库之总体架构
  18. 【刷题】LOJ 2480 「CEOI2017」One-Way Streets
  19. TED #03# 10 ways to have a better conversation
  20. java计算两个日期之间相隔的月份(向下取整)

热门文章

  1. 模拟搭建Web项目的真实运行环境(三)
  2. JS && JSON
  3. GD库处理图像
  4. Python爬虫Scrapy框架入门(2)
  5. Windows内核遍历驱动模块源码分析
  6. [转载]config文件的一个很好的实现
  7. JavaScript预解析1
  8. NOIP2008 ISBN号码(一桶水)【A005】
  9. MYSQL trigger 个人记录
  10. JBD日志的定位、分析和恢复