本文介绍了伪类型的定义及相关语法。
伪类型
名字 | 描述 |
| 表示一个函数可以接受任意输入数据类型 |
| 表示一个函数可以接受任意数据类型 |
| 表示一个函数可以接受任意数组数据类型 |
| 表示一个函数可以接受任意非数组数据类型 |
| 表示一个函数可以接受任意枚举数据类型 |
| 表示一个函数可以接受任意范围数据类型 |
| 指示函数接受任何数据类型,并自动将多个参数提升为通用数据类型 |
| 指示函数接受任何数组数据类型,并自动将多个参数提升为通用数据类型 |
| 指示函数接受任何非数组数据类型,并将多个参数自动提升为通用数据类型 |
| 指示函数接受任何范围数据类型,并将多个参数自动提升为通用数据类型 |
| 表示一个函数接受或者返回一个非空结尾的C字符串。 |
| 表示一个函数接受或返回一个服务器内部数据类型。 |
| 一个被声明为返回 |
| 一个被声明为返回 |
| 一种表访问方法处理程序,声明要返回 |
| 一个被声明为返回 |
| 一个被声明为返回 |
| 标识一个接收或者返回一个未指定的行类型的函数。 |
| 一个被声明为返回 |
| 一个被声明为返回 |
| 标识一种对事件触发器可用的 DDL 命令的表达。 |
| 表示一个函数不返回值。 |
| 标识一种还未被解析的类型,例如一个未修饰的字符文本。 |
用 C 编写的函数(不管是内建的还是动态载入的)可以被声明为接受或返回这些为数据类型的任意一种。函数的作者应当保证当一个伪数据类型被用作一个参数类型时函数的行为是安全的。
用过程语言编写的函数只有在其实现语言允许的情况下才能使用伪类型。 目前大部分过程语言都禁止使用伪类型作为一种参数类型,并且只允许使用void
和record
作为结果类型(如果函数被用于一个触发器或者事件触发器, trigger
或者event_trigger
也被允许作为结果类型)。
internal
伪类型用于定义只在数据库系统内部调用的函数,这些函数不会被 SQL 直接调用。如果一个函数拥有至少一个internal
类型的参数,则它不能从 SQL 中被调用。为了保持这种限制的类型安全性,遵循以下编码规则非常重要:不要创建任何被声明要返回internal
的函数,除非它有至少一个internal
参数。