|
一、直接调用的例子:
--建被调用存储过程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语句就可以了。上面已经有了两个例子,懂得用存储过程的一看就
能明白,在这就不多啰嗦了 |