SQL用一个存储过程调用另一个存储过程

一、直接调用的例子:

--建被调用存储过程B
create procedure B
 @Sql nvarchar(500) = null, 
 @outpara nvarchar(500) output
as
declare @sqlstr nvarchar(500)
begin
 set @outpara = @Sql
end

--建调用存储过程A
create procedure A
 @Sql nvarchar(500)
as
declare @sqlstr nvarchar(500)
begin
 exec B @Sql,@sqlstr output
 print @sqlstr
 exec sp_executesql @sqlstr
end

--执行
exec A 'select * from Auditing'

二、根据需要可以灵活变通,如:


alter procedure B
 @Sql nvarchar(500) = null, 
 @outpara nvarchar(500) output
as
declare @sqlstr nvarchar(500)
begin
 set @outpara = 'select * from Auditing where flag='+@Sql --Auditing是表名,flag是一个int类型的字段名
end

----------------------------------
alter procedure A
 @Sql nvarchar(500)
as
declare @sqlstr nvarchar(500)
begin
 exec B @Sql,@sqlstr output
 print @sqlstr
 exec sp_executesql @sqlstr
end

----------------------------------
exec A '2' 

三、想实现动态调用,可以在A中加一参数@Proc,把exec B @Sql,@sqlstr output中的“B”存储过程名换

成对应的参数名@Proc,并修改相应SQL语句就可以了。上面已经有了两个例子,懂得用存储过程的一看就

能明白,在这就不多啰嗦了

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值