列出所有用户定义的PostgreSQL函数的方法是什么?

时间:2017-05-23 19:49:37

标签: postgresql

PostgreSQL提供命令\ dv列出所有视图。是否有类似的方法列出所有用户定义的函数,或者可能只列出特定用户定义的函数? \ sf要求您知道函数的名称,它将提供函数的定义。 \ df列出了所有功能(并且有很多功能)。我想要一种方法来显示我已定义的功能列表。

2 个答案:

答案 0 :(得分:7)

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

对于\df,这是:

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;

您可以通过以下方式调整将where子句更改为:

AND n.nspname = 'public'

相当于\df public.*

如果您选中the documentation of pg_proc,您会发现有一个proowner列,因此您也可以运行:

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"
FROM pg_catalog.pg_proc p
  JOIN pg_catalog.pg_roles u ON u.oid = p.proowner
  LEFT JOIN pg_catalog.pg_namespace n ON n.oid = p.pronamespace
WHERE pg_catalog.pg_function_is_visible(p.oid)
  AND n.nspname = 'public' 
  AND u.rolname = current_user --<< this limits the functions to those that the current user owns.

答案 1 :(得分:0)

我不确定这个命令是否完全准确,但它似乎向我展示了特定角色拥有的所有功能:

SELECT routine_name, grantee FROM information_schema.routine_privileges WHERE grantee = '<role>';

无论如何,它给了我期望看到的结果。