如何在一个存储过程调用另一个带有输入参数的存储过程

xinuaile 2003-10-09 12:32:25
要调用 下面proc ,并且 多了一句 SELECT ProductName, UnitPrice
FROM Products
WHERE ProductID = @MyProductID ,必须也得 声明这么多参数 ?

===========================

ALTER PROCEDURE AddProduct2
@MyProductName nvarchar(40),
@MySupplierID int,
@MyCategoryID int,
@MyQuantityPerUnit nvarchar(20),
@MyUnitPrice money,
@MyUnitsInStock smallint,
@MyUnitsOnOrder smallint,
@MyReorderLevel smallint,
@MyDiscontinued bit
AS

DECLARE @MyProductID int

-- insert a row into the Products table
INSERT INTO Products (
ProductName, SupplierID, CategoryID, QuantityPerUnit,
UnitPrice, UnitsInStock, UnitsOnOrder, ReorderLevel,
Discontinued
) VALUES (
@MyProductName, @MySupplierID, @MyCategoryID, @MyQuantityPerUnit,
@MyUnitPrice, @MyUnitsInStock, @MyUnitsOnOrder, @MyReorderLevel,
@MyDiscontinued
)

SET @MyProductID = SCOPE_IDENTITY()

RETURN @MyProductID
...全文
112 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
qqdao 2003-12-03
  • 打赏
  • 举报
回复
在存储中这么调用
EXEC @iRet = Common_PreCheckOutBill @iCardId,0,@iBalance OUTPUT,@iCardOverDraft OUTPUT,@cMsg OUTPUT --检查余额

被调存储这样的
CREATE PROCEDURE Common_PreCheckOutBill
@iCardId bigint , --会员卡内部编号
@iModule int , --要预结帐的模块
@iBalance money OUTPUT , --返回结帐后的余额
@iCardOverDraft money OUTPUT , --返回该卡透支限额
@cMessage varchar(100) OUTPUT --返回信息
火电 2003-12-03
  • 打赏
  • 举报
回复
create procedure aaa
@name varchar(20)
as


execute bb(要调用的存储过程)@name


return(0)
zhongkeruanjian 2003-10-10
  • 打赏
  • 举报
回复
不想声明这么多参数也可以,就是全在一起做,如果你的第二个存储过程不是要被复用的话,
zhongkeruanjian 2003-10-10
  • 打赏
  • 举报
回复
你写存储过程时就当是在查询分析器里面写就是了!!
所以你要在存储过程里执行另外一个存储过程的话,
那还不是用EXEC xxx 'DDD','DDDF'
只不过如果你的存储过程中如果要做的事是一步到位的话,就要用BEGIN TRANSACTION和COMMIT TRANSACTION
xinuaile 2003-10-10
  • 打赏
  • 举报
回复
具体如何作 ? 如何在一个存储过程调用另一个带有输入参数的存储过程
stoway 2003-10-09
  • 打赏
  • 举报
回复
是的,调用另一个procedure用exec 存储过程名 参数1,参数2.....
xinuaile 2003-10-09
  • 打赏
  • 举报
回复
具体如何作 ? 如何在一个存储过程调用另一个带有输入参数的存储过程

62,041

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧