返回介绍

I. 教程

II. SQL 语言

III. 服务器管理

IV. 客户端接口

V. 服务器端编程

VI. 参考手册

VII. 内部

VIII. 附录

8.13. 伪类型

发布于 2019-09-30 03:06:07 字数 1551 浏览 1024 评论 0 收藏 0

PostgreSQL类型系统包含一系列特殊用途的条目,它们按照类别来说叫做伪类型。伪类型不能作为字段的数据类型,但是它可以用于声明一个函数的参数或者结果类型。伪类型在一个函数不只是简单地接受并返回某种 SQL 数据类型的情况下很有用。表8-20列出了所有的伪类型。

表8-20. 伪类型

名字描述
any表示一个函数接受任何输入数据类型
anyarray表示一个函数接受任意数组数据类型(参阅节33.2.5)
anyelement表示一个函数接受任何数据类型(参阅节33.2.5)
cstring表示一个函数接受或者返回一个空结尾的 C 字符串
internal表示一个函数接受或者返回一种服务器内部的数据类型
language_handler一个过程语言调用处理器声明为返回 language_handler
record标识一个函数返回一个未声明的行类型
trigger一个触发器函数声明为返回 trigger
void表示一个函数不返回数值
opaque一个已经过时的类型,以前用于所有上面这些用途

用 C 编写的函数(不管是内置的还是动态装载的)都可以声明为接受或者返回这样的伪数据类型。在把伪类型用做函数参数类型的时候,保证函数行为正常就是函数作者的任务了。

用过程语言编写的函数只能根据它们的实现语言是否可以使用伪类型而使用它。目前,过程语言都不允许使用伪类型作为参数类型,并且只允许使用 voidrecord 作为结果类型(如果函数用做触发器,那么加上 trigger)。一些多态的函数还支持使用 anyarrayanyelement 类型。

伪类型 internal 用于声明那种只能在数据库系统内部调用的函数,它们不能直接在 SQL 查询里调用。如果函数至少有一个 internal 类型的参数,那么我们就不能从 SQL 里调用它。为了保留这个限制的类型安全,我们一定要遵循这样的编码规则:不要创建任何声明为返回 internal 的函数,除非它至少有一个 internal 参数。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文