首页 SQLServer SQL一个存储过程调用另一个存储过程语法

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

作者:胡同里的砖头 围观群众:679 更新于:2013-12-19

 

一、直接调用的例子:

--建被调用存储过程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】
  • 非特殊说明,本文版权归【胡同里的砖头】个人博客 所有,转载请注明出处.
留言评论
站点声明:
1、本站【胡同里的砖头】个人博客,借鉴网上一些博客模板,取其各优点模块自行拼装开发,本博客开发纯属个人爱好。
2、所有笔记提供给广大用户交流使用,可转载,可复制,纯个人开发所遇问题锦集记录使用
Copyright © huzlblog.com All Rights Reserved. 备案号:苏ICP备2021056683号-8