如何从 PostgreSQL 中的函数访问外部作用域变量?
How to access outer scope variables from a function in PostgreSQL?
我有这个代码:
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 not exist"。有没有办法在函数中访问外部变量?
不,那行不通,因为该函数与您的 DO
块没有任何联系。它是一个持久性数据库对象,在 DO
块完成后将继续存在于数据库中。
本质上,一个函数只是一个带有函数体的字符串(和一些元数据,参见pg_proc
);在这种情况下,函数体由开始和结束之间的文本组成 $f$
。当函数为 运行.
时,它由语言处理程序解释
您可以在函数中引用的唯一数据库数据是其他持久数据库对象,DO
块中的变量不是其中之一。
Postgre 中没有全局变量SQL 除了——在某种程度上——配置参数。您可以使用 SET
和 SHOW
SQL 命令访问它们,并且在代码中更方便地使用 set_config
和 current_setting
函数。
或使用动态SQL:
DO $$
DECLARE
NODE_ID bigint := 46;
src text := format('
CREATE OR REPLACE FUNCTION funk()
RETURNS bigint AS $f$
BEGIN
RETURN %s;
END;
$f$ LANGUAGE plpgsql;
', NODE_ID::text);
BEGIN
execute src;
RAISE NOTICE '%', funk();
END $$;
(对我有用,登陆你的问题寻找相同问题的解决方案)
我有这个代码:
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 not exist"。有没有办法在函数中访问外部变量?
不,那行不通,因为该函数与您的 DO
块没有任何联系。它是一个持久性数据库对象,在 DO
块完成后将继续存在于数据库中。
本质上,一个函数只是一个带有函数体的字符串(和一些元数据,参见pg_proc
);在这种情况下,函数体由开始和结束之间的文本组成 $f$
。当函数为 运行.
您可以在函数中引用的唯一数据库数据是其他持久数据库对象,DO
块中的变量不是其中之一。
Postgre 中没有全局变量SQL 除了——在某种程度上——配置参数。您可以使用 SET
和 SHOW
SQL 命令访问它们,并且在代码中更方便地使用 set_config
和 current_setting
函数。
或使用动态SQL:
DO $$
DECLARE
NODE_ID bigint := 46;
src text := format('
CREATE OR REPLACE FUNCTION funk()
RETURNS bigint AS $f$
BEGIN
RETURN %s;
END;
$f$ LANGUAGE plpgsql;
', NODE_ID::text);
BEGIN
execute src;
RAISE NOTICE '%', funk();
END $$;
(对我有用,登陆你的问题寻找相同问题的解决方案)