sql server 输出参数

本文介绍了一个SQL存储过程的示例,演示了如何通过存储过程更新数据库中的特定字段值,并展示了如何将执行结果赋值给变量。
idhebeishandongtyperiqi
114012012014-04-13
213012022014-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 然后可以使用被赋值的参数参与运算

  

转载于:https://www.cnblogs.com/mandyguan/p/3708497.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值