Return 来自 postgres 函数的多个输出变量
Return multiple output variables from postgres function
当我 运行 下面的函数时,我在两个输出值 p_V_RESULT
和 p_V_ERROR_MSG
中得到空值。可能是什么问题?
RAISE INFO
显示分配的值:
INFO: p_V_RESULT,T,p_V_ERROR_MSG
CREATE OR REPLACE FUNCTION public.CheckSessionFailed (
IN p_V_CHK_SESSION_ID bigint,
IN p_V_ERROR_COMMENT varchar(1000) ,
OUT p_V_RESULT char(1) ,
OUT p_V_ERROR_MSG varchar(1000)
)
AS $$
DECLARE
p_V_RESULT char(1) := 'T';
p_V_ERROR_MSG varchar(1000) := NULL;
errMsg text;
errState text;
errContext text;
r_rec record;
BEGIN
p_V_RESULT := 'T';
p_V_ERROR_MSG := '';
UPDATE CHECK_SESSION
SET SEVERITY_CD = 'FATAL',
SESSION_COMMENT = 'Check Session Failed: ' || COALESCE(p_V_ERROR_COMMENT, ''),
SESSION_END_DATE = NOW(),
UPDATED_STATUS_FLG = 'Y',
LAST_UPDATED = NOW()
WHERE CHK_SESSION_ID = p_V_CHK_SESSION_ID;
RAISE INFO 'p_V_RESULT,%,p_V_ERROR_MSG,%',p_V_RESULT,p_V_ERROR_MSG;
EXCEPTION
WHEN OTHERS THEN
GET STACKED DIAGNOSTICS
errState = RETURNED_SQLSTATE,
errMsg = MESSAGE_TEXT,
errContext = PG_EXCEPTION_CONTEXT;
p_V_ERROR_MSG := 'SQL State: '|| errState || ';Message ' || errMsg || '; Context '|| errContext;
p_V_RESULT := 'F';
END;
$$ LANGUAGE plpgsql;
函数中的 OUT
参数会自动定义一个具有参数名称的变量。
您的明确声明
DECLARE
p_V_RESULT char(1) := 'T';
p_V_ERROR_MSG varchar(1000) := NULL;
覆盖并隐藏这些参数。所以你最终分配给了错误的变量。
解决方案是删除这些第二个变量声明。
当我 运行 下面的函数时,我在两个输出值 p_V_RESULT
和 p_V_ERROR_MSG
中得到空值。可能是什么问题?
RAISE INFO
显示分配的值:
INFO: p_V_RESULT,T,p_V_ERROR_MSG
CREATE OR REPLACE FUNCTION public.CheckSessionFailed (
IN p_V_CHK_SESSION_ID bigint,
IN p_V_ERROR_COMMENT varchar(1000) ,
OUT p_V_RESULT char(1) ,
OUT p_V_ERROR_MSG varchar(1000)
)
AS $$
DECLARE
p_V_RESULT char(1) := 'T';
p_V_ERROR_MSG varchar(1000) := NULL;
errMsg text;
errState text;
errContext text;
r_rec record;
BEGIN
p_V_RESULT := 'T';
p_V_ERROR_MSG := '';
UPDATE CHECK_SESSION
SET SEVERITY_CD = 'FATAL',
SESSION_COMMENT = 'Check Session Failed: ' || COALESCE(p_V_ERROR_COMMENT, ''),
SESSION_END_DATE = NOW(),
UPDATED_STATUS_FLG = 'Y',
LAST_UPDATED = NOW()
WHERE CHK_SESSION_ID = p_V_CHK_SESSION_ID;
RAISE INFO 'p_V_RESULT,%,p_V_ERROR_MSG,%',p_V_RESULT,p_V_ERROR_MSG;
EXCEPTION
WHEN OTHERS THEN
GET STACKED DIAGNOSTICS
errState = RETURNED_SQLSTATE,
errMsg = MESSAGE_TEXT,
errContext = PG_EXCEPTION_CONTEXT;
p_V_ERROR_MSG := 'SQL State: '|| errState || ';Message ' || errMsg || '; Context '|| errContext;
p_V_RESULT := 'F';
END;
$$ LANGUAGE plpgsql;
函数中的 OUT
参数会自动定义一个具有参数名称的变量。
您的明确声明
DECLARE
p_V_RESULT char(1) := 'T';
p_V_ERROR_MSG varchar(1000) := NULL;
覆盖并隐藏这些参数。所以你最终分配给了错误的变量。
解决方案是删除这些第二个变量声明。