如何在postgresql打印函数和触发器源代码?请让我知道,如果有人知道查询显示的功能,触发器源代码。
当前回答
不仅仅是显示函数,还可以获得就地编辑功能。
\ef <function_name>非常方便。它将以可编辑的格式打开函数的源代码。 您不仅可以查看它,还可以编辑和执行它。
只有\ef而没有function_name将打开可编辑的CREATE FUNCTION模板。
进一步参考-> https://www.postgresql.org/docs/9.6/static/app-psql.html
其他回答
此外,对于@franc的答案,您可以使用SQL接口:
select
prosrc
from pg_trigger, pg_proc
where
pg_proc.oid=pg_trigger.tgfoid
and pg_trigger.tgname like '<name>'
(从这里取:http://www.postgresql.org/message-id/Pine.BSF.4.10.10009140858080.28013-100000@megazone23.bigpanda.com)
功能:
查询pg_proc视图,如下所示
select proname,prosrc from pg_proc where proname= your_function_name;
另一种方法是只执行公共的\df和\ef,它们可以列出函数。
skytf=> \df
List of functions
Schema | Name | Result data type | Argument data types | Type
--------+----------------------+------------------+------------------------------------------------+--------
public | pg_buffercache_pages | SETOF record | | normal
skytf=> \ef pg_buffercache_pages
它将显示函数的源代码。
触发器:
我不知道是否有一个直接的方法来获得源代码。只要知道下面的方法,也许会对你有所帮助!
步骤1:获取触发器的表oid:
skytf=> select tgrelid from pg_trigger where tgname='insert_tbl_tmp_trigger'; tgrelid --------- 26599 (1 row)
步骤2:获取上述oid的表名!
skytf=> select oid,relname from pg_class where oid=26599; oid | relname -------+----------------------------- 26599 | tbl_tmp (1 row)
步骤3:列出表信息
skytf=> \d tbl_tmp
它将向您显示表触发器的详细信息。触发器通常使用函数。因此,您可以获得触发器函数的源代码,就像上面我指出的那样!
自版本:psql (9.6.17, server 11.6)
我已经尝试了以上所有的答案,但对我来说
postgres=> \sf jsonb_extract_path_text
CREATE OR REPLACE FUNCTION pg_catalog.jsonb_extract_path_text(from_json jsonb, VARIADIC path_elems text[])
RETURNS text
LANGUAGE internal
IMMUTABLE PARALLEL SAFE STRICT
AS $function$jsonb_extract_path_text$function$
postgres=> \df+
ERROR: column p.proisagg does not exist
LINE 6: WHEN p.proisagg THEN 'agg'
^
HINT: Perhaps you meant to reference the column "p.prolang".
Df似乎不适合我。
有很多可能性。最简单的方法是使用pgAdmin并从SQL窗口获取。然而,如果你想通过编程方式获得这些,那么检查pg_proc和pg_trigger系统目录或例程,并从信息模式中触发视图(这是SQL的标准方式,但它可能不包括所有特性,特别是特定于postgresql的特性)。例如:
SELECT
routine_definition
FROM
information_schema.routines
WHERE
specific_schema LIKE 'public'
AND routine_name LIKE 'functionName';
\sf function_name在PSQL中产生单个函数的可编辑源代码。
从https://www.postgresql.org/docs/9.6/static/app-psql.html:
\ [+] function_description瑞士法郎 该命令以CREATE或REPLACE function命令的形式获取并显示命名函数的定义。 如果将+追加到命令名后,则输出行编号,函数体的第一行为第1行。
推荐文章
- SQL:从时间戳日期减去1天
- PostgreSQL删除所有内容
- 为什么PostgreSQL要对索引列进行顺序扫描?
- PostgreSQL INSERT ON冲突更新(upsert)使用所有排除的值
- 如何检查一个表是否存在于给定的模式中
- 如何将整数转换为字符串作为PostgreSQL查询的一部分?
- Psycopg2:用一个查询插入多行
- PostgreSQL返回JSON数组的结果集?
- PostgreSQL通配符LIKE用于单词列表中的任何一个
- 检查Postgres JSON数组是否包含字符串
- psql: FATAL: Peer authentication failed for user "dev"
- 如何在Postgres/SQL中获得两个整数的最小/最大值?
- 如何在postgresql中显示函数,过程,触发器源代码?
- 如何用postgres将间隔转换为小时数?
- 在postgresql中将查询结果按月和年分组