我来自Server的悠久历史,并试图学习PL/PGSQL。我最近发现了PG11特性创建过程,它允许在其体内进行内部事务。
作为一项学习练习,我创建了以下内容:
DROP PROCEDURE IF EXISTS test_proc();
CREATE PROCEDURE test_proc()
LANGUAGE plpgsql
AS $$
BEGIN
DROP TABLE IF EXISTS a;
CREATE TABLE a (aid int);
COMMIT;
END;
$$;
call test_proc();它在PSQL中工作得很好,但是当我在PGAdmin 4的查询工具中执行它时,它会出现以下错误
错误:无效的事务终止
上下文: PL/pgSQL函数test_proc()第5行提交
SQL状态: 2D000
有人能解释一下发生了什么事吗?我猜想这个过程实际上是有效的,问题可能在查询工具中,可能是错误地处理包含的提交。
有什么建议来解决这个问题吗?
谢谢!
发布于 2019-09-20 05:33:03
在Pgadmin创建过程中,请尝试用函数替换过程,并添加返回类型,这样就可以了。
DROP FUNCTION IF EXISTS test_proc();
CREATE FUNCTION test_proc()
RETURNS VOID
LANGUAGE plpgsql
AS $$
BEGIN
DROP TABLE IF EXISTS a;
CREATE TABLE a (aid int);
COMMIT;
END;
$$;发布于 2019-09-20 10:32:09
请您尝试取消检查pgAdmin4中的自动提交和自动回滚选项吗?
您可以在查询工具中的“执行”按钮附近找到下拉列表。

https://stackoverflow.com/questions/58021987
复制相似问题