【问题标题】:Where are postgresql aggregate functions stored?postgresql 聚合函数存储在哪里?
【发布时间】:2018-10-08 19:11:56
【问题描述】:

我创建了一个聚合函数,我什至可以使用它。但我在任何数据库层次结构下都找不到它。它不在函数下。

它们是否隐藏在视线之外?我正在使用 pgAdmin ide。

【问题讨论】:

  • 编辑、查看其妆容等...
  • 在 psql 中:\da[S] [PATTERN] list aggregates
  • 聚合函数 gui 未在 pgAdmin4 中实现,这就是它未显示在浏览器树中的原因。
  • 我使用 pgadmin3 是因为我只是讨厌 pgadmin4,聚合函数在那里也不可见。

标签: postgresql aggregate-functions pgadmin-4


【解决方案1】:

查找此类查询的最佳方法是将 psql 与 --echo-hidden 选项一起使用。然后运行 ​​psql 元命令,您将看到使用的查询

SELECT n.nspname as "Schema",
  p.proname as "Name",
  pg_catalog.pg_get_function_result(p.oid) as "Result data type",
  pg_catalog.pg_get_function_arguments(p.oid) as "Argument data types",
 CASE
  WHEN p.proisagg THEN 'agg'
  WHEN p.proiswindow THEN 'window'
  WHEN p.prorettype = 'pg_catalog.trigger'::pg_catalog.regtype THEN 'trigger'
  ELSE 'normal'
 END as "Type"
FROM pg_catalog.pg_proc p
     LEFT JOIN pg_catalog.pg_namespace n ON n.oid = p.pronamespace
WHERE pg_catalog.pg_function_is_visible(p.oid)
      AND n.nspname <> 'pg_catalog'
      AND n.nspname <> 'information_schema'
ORDER BY 1, 2, 4;

【讨论】:

  • 谢谢,我会保存这个。我认为这是我使用的 IDE (pgAdmin)。我切换到 DBeaver,我可以在层次结构中看到 Agg 函数。
猜你喜欢
  • 2010-11-11
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-07-03
相关资源
最近更新 更多