从 Python 执行 Postgresql 函数

2023-12-25

我在数据库中创建了一个函数(取自 wiki.postgresql.org),用于获取近似行数。

CREATE FUNCTION ais_history.count_estimate(query text)
        RETURNS integer
        LANGUAGE plpgsql AS
        $func$
                DECLARE
                        rec   record;
                        rows  integer;
                BEGIN
                FOR rec IN EXECUTE 'EXPLAIN ' || query LOOP
                        rows := substring(rec."QUERY PLAN" FROM ' rows=([[:digit:]]+)');
                        EXIT WHEN rows IS NOT NULL;
                END LOOP;

                RETURN rows;
                END
        $func$;

当我使用 psql cli 中的函数时,它工作正常。

db=> SELECT count_estimate('SELECT * FROM schema.table_name');
 count_estimate
----------------
              4
(1 row)

但是,当我使用 SQLalchemy core 或 psycopg2 从 Python 运行它时,它会出现错误。

conn.autocommit = True
cursor = conn.cursor()
cursor.execute("SELECT count_estimate('SELECT * FROM schema.table_name');")
conn.commit()
conn.close()

错误输出

UndefinedFunction                         Traceback (most recent call last)
Input In [91], in <cell line: 8>()
      5 conn.autocommit = True
      6 cursor = conn.cursor()
----> 8 cursor.execute("SELECT count_estimate('SELECT * FROM schema.table_name');")
     10 conn.commit()
     11 conn.close()

UndefinedFunction: function count_estimate(unknown) does not exist
LINE 1: SELECT count_estimate('SELECT * FROM schema.table_name...
               ^
HINT:  No function matches the given name and argument types. You might need to add explicit type casts.

如何运行原始 sql 来获取函数输出?


None

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

从 Python 执行 Postgresql 函数 的相关文章

随机推荐

  • 如何检查变量是否是数组?

    我对变量名有一个循环 我需要检查变量的内容是否是数组 for varname in AA BB CC do local val if varname is array then how can I perform this test ech
  • 如何在 Chrome DevTools 网络面板中按文本和属性进行过滤?

    我想通过 URL 中的方法属性和文本过滤 Chrome DevTool 的网络面板 例如 如果我在 URL 中搜索文本 chromequestion 并且仅搜索 HTTP GET 请求 忽略 PUT POST DELETE 等 I am a
  • JOOQ 查询的时间戳精度

    我有一个 PSQL 原始查询 我想将其转换为 JOOQ 查询 SELECT DISTINCT date trunc day ref date AS refdate FROM income WHERE probos id probosId 我
  • 在 python lxml 库中使用西里尔字母的正确方法是什么

    我尝试生成其中包含西里尔字母符号的 xml 文件 但结果却出人意料 避免这种结果的最简单方法是什么 例子 from lxml import etree root etree Element print etree tostring root
  • 监听元素的创建,并在元素出现在 Chrome 扩展程序的页面上时触发事件

    是否可以让 Chrome 扩展监听尚未创建的元素的出现 假设用户单击按钮并且单击事件创建一个元素 div My Div div 并将其添加到页面 DOM 是否可以设置一个侦听器 在该元素出现时自动触发事件 或者我是否必须每隔 X 毫秒轮询页
  • 智能字段注释 - valuehelp 下拉菜单

    我有一个值帮助字段 并且只想在下拉列表中查看说明 而不是代码 选择后 想要将代码存储在另一个处于隐藏模式的字段中 为此 我定义了以下注释
  • 还有比 PHPDoc 更好的吗? [关闭]

    Closed 这个问题正在寻求书籍 工具 软件库等的推荐 不满足堆栈溢出指南 help closed questions 目前不接受答案 有没有人使用其他任何东西来记录他们的PHP代码比PHPDoc 是否有任何工具可以读取相同的文档语法但提
  • 在 PowerShell 中启用本地用户权限分配

    我之前问过类似的问题 以便在某个域用户的 PowerShell 中获得本地用户权限 现在我想启用该权限 我希望启用一些权限 但在本示例中 我将使用登录作为批处理作业 默认情况下 Windows Server 2008 中没有 Ntright
  • Knockout 中 Observable 的设置值未更新

    每天都有大量的问题链接回为什么我不能设置可观察值的值 而不是有这么多不同的答案说同样的事情 我想创建一个问题供每个人参考 Knockout Observable Observable Array 的设置值不会更新 设置我的可观察 obser
  • 使用 OpenXML 将背景图像添加到 Excel

    我正在使用 Open XML 创建 Excel 我想向 Excel 添加背景图像 不要告诉我将图像添加到 Excel 并与 OpenXML Productivity Tool 进行比较 请让我知道执行此操作的提取方法 我已经深入研究使用 O
  • 如何在Flask Sqlalchemy中分离Master Slave(DB读/写)

    我正在尝试通过 Flask Sqlalchemy 分离读取和写入数据库操作 我正在使用绑定来连接到 mysql 数据库 我想在主机中执行写入操作并从从机中读取操作 似乎没有内置的方法来处理这个问题 我是Python新手 很惊讶像这样急需的功
  • 以低优先级启动进程(使用 Runtime.exec / ProcessBuilder.start)

    我需要在低优先级下启动一个 CPU 密集型系统进程 这样它就不会减慢我的服务器速度 我怎样才能在 Linux 上做到这一点 这与这个问题类似 使用 Runtime exec ProcessBuilder start 以低优先级启动 Java
  • Java随机类不是真正随机的?

    我正在尝试模拟我发现的数学难题http blog xkcd com 2010 02 09 math puzzle http blog xkcd com 2010 02 09 math puzzle 然而 java random 类返回奇怪的
  • 退出系统调用的正确常量是什么?

    我正在尝试学习 x86 64 汇编 并使用 GCC 作为我的汇编器 我使用的确切命令是 gcc nostdlib tapydn S D ASSEMBLY 我主要使用 gcc 作为其预处理器 这是tapydn S global start i
  • 在:数字之前右对齐 CSS?

    我想要对段落进行编号 而不需要使用有序列表 我试图通过在 CSS 中使用 content counter paragraph 来实现此目的 以便我创建的每个段落块都会在其左侧生成一个数字 pass counter reset paragra
  • 按日期差异对结果排序

    我们有一个按输入日期的 1 个月的日期范围查询的 solr 结果 如果我输入 2012 12 01 我会得到从 2012 11 01 到 2013 01 01 的结果集 这工作正常 但我们希望在与输入日期的日期差异之后对结果进行排序 例如
  • HtmlUnit 下载文件后无法检索页面

    我在 Java 中的 HtmlUnit 中遇到了这个奇怪的问题 我用它从网站下载一些数据 过程是这样的 1 登录 2 对于每个元素 汽车 3 搜索汽车 4 从链接下载 zip 文件 代码 创建网络客户端 webClient new WebC
  • codeigniter 类别 -> 子类别 -> 子子类别系统

    好的 所以我很新codeigniter从我现在所学到的来看 我不知道如何创建一个动态category gt subcategory gt subsubcategory system 您能给我一些指导吗 一些参考资料 任何可以指导我应该学习什
  • 未知方法 process.openStdin()

    我正在尝试将 grep 结果通过管道传输到 nodejs 脚本中 我发现我应该从 process stdin 接收数据 我还发现了几种使用标准输入的方法 但它们是不同的 我无法找到有关它的所有信息 我知道四种方法 前 3 种以var dat
  • 从 Python 执行 Postgresql 函数

    我在数据库中创建了一个函数 取自 wiki postgresql org 用于获取近似行数 CREATE FUNCTION ais history count estimate query text RETURNS integer LANG