zoukankan      html  css  js  c++  java
  • sql server 输出参数

    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

    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)' 
    

      如果不能理解上面的例子可以试一下这个简单的

     输出参数 
    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 output 
    select @num   --遇到的问题是关于不知道如果使用exce执行结果赋值给另一个变量,这部分解决了这个问题
    ---执行时将参数输出output 然后可以使用被赋值的参数参与运算
    

      

    要么读书,要么旅行,身体和灵魂总有一个在路上
  • 相关阅读:
    .Matrix-第三篇冲刺随笔
    .Matrix-第二篇冲刺随笔
    Alpha冲刺-第九次冲刺笔记
    Alpha冲刺-第八次冲刺笔记
    Alpha冲刺-第七次冲刺笔记
    Alpha冲刺-第六次冲刺笔记
    Alpha冲刺-第五次冲刺笔记
    Alpha冲刺-第四次冲刺笔记
    Alpha冲刺-第三次冲刺笔记
    Alpha冲刺-第二次冲刺笔记
  • 原文地址:https://www.cnblogs.com/mandyguan/p/3708497.html
Copyright © 2011-2022 走看看