35.8. 内部函数

内部函数都是用C写的函数,它们已经通过静态链接的方式嵌入 PostgreSQL服务器进程中了。 函数定义的"函数体"确定了函数的C语言名称, 它不必与给 SQL 使用的名称相同。出于向下兼容考虑, 一个空的函数体也可以被接受, 这意味着 C 函数名与 SQL 函数名相同。

通常,所有在服务器里出现的内部函数都在数据库初始化时定义(参阅Section 17.2)。 但是用户可以用CREATE FUNCTION为内部函数创建额外的别名。 内部函数在CREATE FUNCTION命令里是带着internal语言名声明的。 比如,要给sqrt函数创建一个别名:

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

(大多数内部函数都应该声明为"strict")。

Note: 并非所有"预定义"的函数都像上面那样是"内部的"。 有些预定义的函数是用 SQL 写的。