SQL中获得EXEC后面的sql语句或者存储过程的返回值的方法

         前言:在数据库程序开发的过程中,我们经常会碰到利用EXEC来执行一段需要返回某些值的sql语句(通常是构造动态sql语句时使用),或者在一个存储过程中利用EXEC调用另一个有返回值的存储过程(必须获得返回值),那么如何获得这些返回值呢?

1,EXEC执行sql语句的情况

     declare   @rsql   varchar ( 250 )
        
declare   @csql   varchar ( 300 )
        
declare   @rc   nvarchar ( 500 )
        
declare   @cstucount   int
        
declare   @ccount   int
        
set   @rsql = ' (select Classroom_id from EA_RoomTime where zc= ' + @zc + '  and xq= ' + @xq + '  and T ' + @time + ' = '' '' ) and ClassroomType= '' 1 '''
        
-- exec(@rsql)
         set   @csql = ' select @a=sum(teststucount),@b=sum(classcount) from EA_ClassRoom where classroom_id in  '
        
set   @rc = @csql + @rsql
        
exec  sp_executesql  @rc ,N ' @a int output,@b int output ' , @cstucount  output, @ccount  output -- 将exec的结果放入变量中的做法
         -- select @csql+@rsql
         -- select @cstucount

 上面的@rc这个sql语句的功能是找出特定时间段里所有有空的教室数量以及这些教室所能容纳的学生人数,因为涉及到动态的sql语句(@csql这句里条件中有一个列名是动态变化的)的构造,所以要放在exec里执行,但是同时我又要返回2个结果,所以执行时的代码为:


        
exec  sp_executesql  @rc ,N ' @a int output,@b int output ' , @cstucount  output, @ccount  output -- 将exec的结果放入变量中的做法
        


这样就将返回值放到了,@cstucount,@ccount两个变量中,得到了我们想要的结果。

2,exec执行带返回值的存储过程的情况

我们来看一个简单的存储过程:

create   procedure  ProTest
(
         
@name   varchar ( 10 ),
         
@money   int  output
)
as
begin
        
if ( @name = ' 1 ' )
                  
set   @money = 1000
        
else
                  
set   @money = 2000
end

这个只是一个简单的示例,这个存储过程返回的是@money 这个参数的值,那么当我们在另外一个存储过程中调用此存储过程的时候如何获取这个参数呢,方法如下:

declare   @m   int   -- -用来接收返回值的变量
exec  ProTest  @name = ' 1 ' , @money = @m  output  -- 一定要注名是output

就这么简单,我们就获得了返回值,然后就可以利用它了
呵呵。。。这是我在做项目时碰到的情况时的解决办法(当然可能还有其他办法)。。。希望对您有帮助。。。
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL Server 存储过程,你可以执行传入的字符串类型的 SQL 语句,并带有返回值。 以下是一个示例,展示了如何执行传入的字符串类型的 SQL 语句并返回结果: ```sql CREATE PROCEDURE ExecuteSQL @sqlStatement NVARCHAR(MAX), @returnValue INT OUTPUT AS BEGIN -- 执行传入的 SQL 语句并将结果赋值给输出参数 EXEC sp_executesql @sqlStatement, N'@returnValue INT OUTPUT', @returnValue = @returnValue OUTPUT -- 返回结果 SELECT @returnValue AS Result END ``` 在上面的示例存储过程 ExecuteSQL 接受两个参数:@sqlStatement(要执行的字符串类型的 SQL 语句)和 @returnValue(用于存储返回结果的输出参数)。 在存储过程内部,使用 sp_executesql 存储过程来执行传入的 SQL 语句,并将结果赋值给输出参数 @returnValue。 最后,通过 SELECT 语句返回 @returnValue 参数作为结果。 你可以通过以下代码来调用存储过程并执行传入的字符串类型的 SQL 语句,并获取返回的结果: ```sql DECLARE @sql NVARCHAR(MAX) DECLARE @result INT SET @sql = 'SELECT COUNT(*) FROM YourTable' EXEC ExecuteSQL @sql, @result OUTPUT SELECT @result AS Result ``` 在上面的代码,将要执行的 SQL 语句赋值给变量 @sql,定义一个变量 @result,用于接收存储过程返回值。 通过 EXEC 关键字调用存储过程 ExecuteSQL,并传入 @sql 和 @result 作为参数存储过程将执行传入的 SQL 语句并将结果赋值给 @result 变量。 最后,通过 SELECT 语句输出 @result 变量的值作为结果。 请注意,在使用动态 SQL 时,要注意安全性和避免 SQL 注入攻击。可以使用参数化查询或者输入验证来增强安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值