zoukankan      html  css  js  c++  java
  • 用sp_executesql执行动态SQL语句及获得返回值

    过去我执行拼凑出来的动态SQL语句,都直接使用EXEC @sql 的方式。有好几次,都看到有资料说,应该尽量使用 sp_executesql。

    究其原因,是因为仅仅参数不同的情况下,sp_executesql可以重用执行计划,这不就有跟存储过程一样的优势了吗?同时,sp_executesql还可以提供动态SQL语句执行的返回值,方便得很。

    但sp_executesql的使用方式看上去比较复杂,一点都不像EXEC那样直观。

    用法:

    EXEC sp_executesql SQL语句,参数声明,参数


    	CREATE TABLE #tmp(t INT NOT NULL,it DECIMAL(18,4),pt DECIMAL(18,4));
    	INSERT INTO #tmp(t,it,pt) VALUES(1,10.00,15.00);
    	INSERT INTO #tmp(t,it,pt) VALUES(2,20.00,30.00);
    
    	DECLARE @sql NVARCHAR(2000) = N'SELECT @it=it,@pt=pt FROM #tmp WHERE t=@tN;';
    	DECLARE @Param NVARCHAR(500) = N'@tN INT,@it DECIMAL(18,4) OUTPUT,@pt DECIMAL(18,4) OUTPUT';
    	DECLARE @tN INT,@it DECIMAL(18,4),@pt DECIMAL(18,4);
    	
    	SET @tN = 1;
    	--@tN=@tN,第一个@tN是@Param里的声明,而第二个@tN则是外部的声明,其他类似
    	EXEC sp_executesql @sql,@Param,@tN=@tN,@it=@it OUTPUT,@pt=@pt OUTPUT;
    	SELECT @it,@pt;
    	
    	DROP TABLE #tmp;

    为什么有返回值那么重要呢?我在不知道这个用法以前,如果需要捕捉动态SQL语句里的返回值,要借用表对象:

    详见拙作:

    http://blog.csdn.net/leftfist/article/details/12840785


    declare @sql NVARCHAR(MAX) = N'SELECT @i,@j;';
    declare @paramdefine NVARCHAR(MAX) = N'@i INT,@j INT,@k INT=3';
    exec sp_executesql @sql,@paramdefine,@i=1,@j=2;



  • 相关阅读:
    添加事件(jquery)
    闭包导致的问题
    学习之js绑定事件
    第二条 一个类如果有多个参数,考虑用Builder构造者模式
    用Intellij IDEA 创建第一个maven项目!
    OrderSessionHelper查看订单在session是否存在的辅助类
    css——overflow
    css——盒子
    css——外部样式
    css——权重叠加
  • 原文地址:https://www.cnblogs.com/leftfist/p/4257929.html
Copyright © 2011-2022 走看看