sql server 输出参数
            时间:2014-05-09 17:42:32  
            收藏:0  
            阅读:354
        
        
        | id | hebei | shandong | type | riqi | 
| 1 | 140 | 120 | 1 | 2014-04-13 | 
| 2 | 130 | 120 | 2 | 2014-04-13 | 
表A中的数据如上图所示,现在我要处理的一种情况是这样子的,我需要写一个存储过程,代码中会传两个参数shandong,type 的值1 给接收参数@region ,@type,那么我会获得值120,获得之后在原有的数值上加1
| 
       1 
      2 
      3 
      4 
      5 
      6 
      7 
      8 
      9 
      10 
      11 
      12 
      13 
      14 
      15 
      16  | 
    
      DECLARE @region varchar(20),        @type int,        @regionvalue INT 
,        @sqls NVARCHAR(4000)        SET 
@sqls = ‘SELECT @a =‘ 
+ @region            + ‘ FROM  表名 WHERE type=‘ 
+ @type            + ‘ AND riqi = CONVERT(VARCHAR(10), GETDATE(), 120)‘        EXEC 
sp_executesql @sqls, N‘@a int output‘, @regionvalue OUTPUT                 IF @regionvalue IS 
NULL        SET 
@regionvalue = 0                    DECLARE 
@strRegion VARCHAR(MAX)         SET 
@strRegion = ‘UPDATE 表名 SET ‘ 
+ @region + ‘=‘            + CAST(@regionvalue + 1 AS 
NVARCHAR(200)) + ‘  WHERE   type = ‘            + @type + ‘ AND riqi = CONVERT(VARCHAR(10), GETDATE(), 120)‘ | 
如果不能理解上面的例子可以试一下这个简单的
| 
       1 
      2 
      3 
      4 
      5 
      6 
      7 
      8 
      9 
      10 
      11 
      12 
      13  | 
    
      输出参数 declare @num int,  @sqls nvarchar(4000) set 
@sqls=‘select count(*) from tableName‘exec(@sqls) --如何将exec执行结果放入变量中? declare @num int,  @sqls nvarchar(4000) set @sqls=‘select @a=count(*) from tableName ‘exec sp_executesql @sqls,N‘@a int output‘,@num outputselect 
@num   --遇到的问题是关于不知道如果使用exce执行结果赋值给另一个变量,这部分解决了这个问题---执行时将参数输出output 然后可以使用被赋值的参数参与运算 | 
            评论(0)