首页 > 代码库 > sql server 输出参数

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

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