繁体   English   中英

如何在字符串中存储带有参数的SQL Proc名称?

[英]How do I store a SQL Proc name with an argument in a string?

所有这些都在TSQL存储过程中。 我有一个变量,其中包含要执行的存储过程的名称,直到现在,此方法仅用于不带参数的存储过程。 我正在使用troulbe装配一个确实在同一个模具中引起争论的proc。

在我的主驱动程序过程中,我有一行EXECUTE @process_name@process_name通常是类似'database..procedure'的东西,没有任何用处。 如何将存储的proc的名称及其参数放入一个字符串中,以便当我调用EXECUTE @process_name ,它将使用参数执行该过程?

我根本无法更改此执行行,我真的需要将proc名称和参数放入单个字符串@process_name中 我意识到这可能不是最佳做法。

谢谢你的帮助!

您在@process_name中输入了相同的内容,就像在键入时一样:

--Create your Stored Procedure
CREATE PROCEDURE dbo.YourStoredProc
    @FirstVariable VARCHAR(30),
    @SecondVariable VARCHAR(30)
AS
BEGIN
    SELECT @FirstVariable,@SecondVariable
END
GO


DECLARE @process_name VARCHAR(MAX);
--List the name of your stored procedure you want to execute
    --Followed by variables and their values
SET @process_name = 'dbo.YourStoredProc @firstvariable = ''Hello'', @SecondVariable = ''World!'''

EXEC (@process_name)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM