gpt4 book ai didi

sql - 在 SQL Server 中的另一个存储过程中执行一个存储过程

转载 作者:行者123 更新时间:2023-12-03 07:27:33 24 4
gpt4 key购买 nike

如何在 SQL Server 的另一个存储过程中执行一个存储过程?
我将如何传递第二个过程的参数。?

最佳答案

如果您只想通过第二个 SP 执行某些特定操作并且不需要从 SP 返回值,那么只需执行以下操作:

Exec secondSPName  @anyparams

否则,如果您需要第一个 SP 中的第二个 SP 返回的值,则创建一个具有相同列数和第二个 SP 返回的列定义相同的临时表变量。然后你可以在第一个 SP 中获得这些值:
Insert into @tep_table
Exec secondSPName @anyparams

更新:

要将参数传递给第二个 sp,请执行以下操作:
Declare @id ID_Column_datatype 
Set @id=(Select id from table_1 Where yourconditions)

Exec secondSPName @id

更新 2:

假设您的第二个 sp 返回 IdName哪里类型 idintnamevarchar(64)类型。

现在,如果你想在第一个 sp 中选择这些值,那么创建一个临时的 table变量并将值插入其中:
Declare @tep_table table
(
Id int,
Name varchar(64)
)
Insert into @tep_table
Exec secondSP

Select * From @tep_table

这将返回第二个 SP 返回的值。

希望,这可以消除您所有的疑虑。

关于sql - 在 SQL Server 中的另一个存储过程中执行一个存储过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15802511/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com