gpt4 book ai didi

postgresql - 如何从 PostgreSQL 中的函数访问外部作用域变量?

转载 作者:行者123 更新时间:2023-11-29 13:11:14 25 4
gpt4 key购买 nike

我有这个代码:

DO $$
DECLARE
NODE_ID bigint := 46;
BEGIN
CREATE OR REPLACE FUNCTION funk(VAL bigint)
RETURNS bigint AS $f$
BEGIN
RETURN VAL;
END; $f$ LANGUAGE plpgsql;

RAISE NOTICE '%', funk(NODE_ID);
END $$;

我按预期工作并向控制台打印 46。我想去掉参数,因为变量是全局的。但是我收到错误:

DO $$
DECLARE
NODE_ID bigint := 46;
BEGIN
CREATE OR REPLACE FUNCTION funk()
RETURNS bigint AS $f$
BEGIN
RETURN NODE_ID;
END; $f$ LANGUAGE plpgsql;

RAISE NOTICE '%', funk();
END $$;

我得到“NODE_ID 不存在”。有没有办法访问函数中的外部变量?

最佳答案

不,那行不通,因为该函数与您的 DO block 没有任何联系。它是一个持久数据库对象,在 DO block 完成后将继续存在于数据库中。

本质上,一个函数只是一个带有函数体的字符串(和一些元数据,参见pg_proc);在这种情况下,函数体由开始和结束 $f$ 之间的文本组成。它在函数运行时由语言处理程序解释。

您可以在函数中引用的唯一数据库数据是其他持久数据库对象,DO block 中的变量不是其中之一。

除了——在某种程度上——配置参数外,PostgreSQL 中没有全局变量。您可以使用 SETSHOW SQL 命令访问它们,并且在代码中更方便地使用 set_configcurrent_setting 功能。

关于postgresql - 如何从 PostgreSQL 中的函数访问外部作用域变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54457985/

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