更新时间:2024-06-03 GMT+08:00

PG_LANGUAGE

PG_LANGUAGE系统表登记编程语言,用户可以用这些语言或接口写函数或者存储过程。

表1 PG_LANGUAGE字段

名称

类型

引用

描述

oid

oid

-

行标识符(隐含属性;必须明确选择)。

lanname

name

-

语言的名称。

lanowner

oid

PG_AUTHID.oid

语言的所有者。

lanispl

boolean

-

  • true:表示用户定义的语言。
  • false:表示内部语言,比如SQL。

目前,gs_dump仍然使用该字段判断哪种语言需要转储,但是这些可能在将来被其它机制取代。

lanpltrusted

boolean

-

  • true:这是可信语言,意味着系统相信它不会被授予任何正常SQL执行环境之外的权限。
  • false:这是不可信语言。只有初始用户可以用不可信语言创建函数。

lanplcallfoid

oid

PG_PROC.oid

对于非内部语言,这是指向该语言处理器的引用,语言处理器是一个特殊函数, 负责执行以某种语言写的所有函数。

laninline

oid

PG_PROC.oid

这个字段引用一个负责执行“inline”匿名代码块的函数(DO块)。如果不支持内联块则为零。

lanvalidator

oid

PG_PROC.oid

这个字段引用一个语言校验器函数,它负责检查新创建的函数的语法和有效性。如果没有提供校验器,则为零。

lanacl

aclitem[]

-

访问权限。