首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用PGAdmin 4创建事务过程

使用PGAdmin 4创建事务过程
EN

Stack Overflow用户
提问于 2019-09-20 04:54:26
回答 2查看 4.3K关注 0票数 1

我来自Server的悠久历史,并试图学习PL/PGSQL。我最近发现了PG11特性创建过程,它允许在其体内进行内部事务。

作为一项学习练习,我创建了以下内容:

代码语言:javascript
复制
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

有人能解释一下发生了什么事吗?我猜想这个过程实际上是有效的,问题可能在查询工具中,可能是错误地处理包含的提交。

有什么建议来解决这个问题吗?

谢谢!

EN

回答 2

Stack Overflow用户

发布于 2019-09-20 05:33:03

在Pgadmin创建过程中,请尝试用函数替换过程,并添加返回类型,这样就可以了。

代码语言:javascript
复制
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;
$$;
票数 0
EN

Stack Overflow用户

发布于 2019-09-20 10:32:09

请您尝试取消检查pgAdmin4中的自动提交和自动回滚选项吗?

您可以在查询工具中的“执行”按钮附近找到下拉列表。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58021987

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档