一、直接调用的例子:
--建被调用存储过程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语句就可以了。上面已经有了两个例子,懂得用存储过程的一看就
能明白,在这就不多啰嗦了
- 本文标题: SQL一个存储过程调用另一个存储过程语法
- 文章分类:【SQLServer】
- 非特殊说明,本文版权归【胡同里的砖头】个人博客 所有,转载请注明出处.
- 上一篇:switch case语法和用法
- 下一篇: SQL事务回滚语法的问题及其解决的方法