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 = 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 然后可以使用被赋值的参数参与运算 |
要么读书,要么旅行,身体和灵魂总有一个在路上
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步