受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

36.9. 内部函数 #

内部函数由 C 编写并且已经被静态链接到PostgreSQL 服务器中。该函数定义的主体指定该函数的 C 语言名称, 它不必与为 SQL 使用而声明的名称相同。(出于向后兼容的原因,也接受空 主体,此时会认为 C 语言函数名与 SQL 函数名相同。)

通常,所有存在于服务器中的内部函数都在数据库集簇的初始化(见 Section 18.2)期间被声明,但是用户可以使用 CREATE FUNCTION为一个内部函数创建 额外的别名。在CREATE FUNCTION中用 语言名internal来声明内部函数。例如,要为 sqrt函数创建一个别名:

CREATE FUNCTION square_root(double precision) RETURNS double precision
    AS 'dsqrt'
    LANGUAGE internal
    STRICT;

(大部分内部函数应该被声明为严格)。

Note

上述场景中并非所有预定义的函数都是 内部函数。有些预定义的函数由 SQL 编写。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。