无法 return 存储过程中来自链接数据库的值

Unable to return a value from a linked database within stored procedure

我正在尝试编写一个存储过程(或函数,如果更容易的话)来查询链接数据库和 return 一个值,但非常困难。非常感谢任何帮助...

我尝试过的:

CREATE Proc dbo.Sample (@FolderID as VARCHAR(50),
@FolderName varchar(50) OUTPUT)
AS
BEGIN

DECLARE @ParamaterDefinition NVARCHAR(500)
DECLARE @FolderNameRet VARCHAR(50)
DECLARE @TSQL NVARCHAR(4000)

SET @TSQL = N'SELECT folder_name FROM OPENQUERY(LINKDB, ''SELECT 
        folder_name 
    FROM FolderTable
    where folder_id = '+ @FolderID +' and folder_status != 0'')'
SET @ParamaterDefinition = N'@FolderID as VARCHAR(50),
                    @FolderName VARCHAR(50) OUTPUT'
EXEC SP_EXECUTE @TSQL,
@ParamaterDefinition,
@FolderID,
@FolderName = @FolderNameRet output

SELECT @FolderNameRet AS "Output"
SELECT @FolderID AS "FolderID1"
SELECT @TSQL AS "Script"
SELECT @FolderName AS "FolderName1"
SELECT @ParamaterDefinition AS "Parameters"

RETURN @FolderNameRet 
END

使用末尾的 SELECT 语句查看每个变量,生成的脚本很好,可以 运行 单独获取我想要的值。但是@FolderNameRet 仍然是 NULL。

我觉得问题出在我试图 return 一个值不正确,但我尝试过的每一种方法都失败了。

即不要认为我可以在动态脚本中设置 return 值,因为这需要以字符串格式设置为 运行 作为 OPENQUERY 语句的一部分。也尝试使用 EXEC @FolderNameRet = SP_EXECUTE @TSQL 但这也是 returning NULL。

请帮忙!

您可以尝试为@FolderName 变量赋值:

SET @TSQL = N'SELECT @FolderName = folder_name FROM OPENQUERY(LINKDB, ''SELECT 
        folder_name 
    FROM FolderTable
    where folder_id = '+ @FolderID +' and folder_status != 0'')'
SET @ParamaterDefinition = N'@FolderID as VARCHAR(50),
                    @FolderName VARCHAR(50) OUTPUT';

此外,存储过程的 RETURN 是状态 INT 而不是 VARCHAR(50)