2024年9月26日: PostgreSQL 17 发布!
支持的版本:当前 (17) / 16 / 15 / 14 / 13 / 12
开发版本:开发版
不支持的版本:11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2

42.1. 概述 #

PL/Tcl 提供了函数编写者在 C 语言中拥有的大多数功能,但也有一些限制,并增加了 Tcl 可用的强大的字符串处理库。

一个引人注目的良好限制是,所有内容都在 Tcl 解释器的安全上下文中执行。除了安全的 Tcl 的有限命令集之外,只有少数命令可用于通过 SPI 访问数据库并通过 elog() 发送消息。PL/Tcl 无法访问数据库服务器的内部或以 PostgreSQL 服务器进程的权限获得操作系统级别的访问权限,就像 C 函数可以做的那样。因此,可以信任无特权的数据库用户使用此语言;它不会赋予他们无限的权限。

另一个值得注意的实现限制是,Tcl 函数不能用于为新的数据类型创建输入/输出函数。

有时需要编写不受限于安全 Tcl 的 Tcl 函数。例如,可能需要一个发送电子邮件的 Tcl 函数。为了处理这些情况,PL/Tcl 有一个变体,称为 PL/TclU(用于不受信任的 Tcl)。除了使用完整的 Tcl 解释器之外,这与该语言完全相同。如果使用 PL/TclU,则必须将其安装为不受信任的过程语言,以便只有数据库超级用户才能在其内创建函数。 PL/TclU 函数的编写者必须注意该函数不能用于执行任何不需要的操作,因为它能够执行数据库管理员用户可以执行的任何操作。

如果在安装过程的配置步骤中指定了 Tcl 支持,则 PL/TclPL/TclU 调用处理程序的共享对象代码将自动构建并安装在 PostgreSQL 库目录中。要在特定数据库中安装 PL/Tcl 和/或 PL/TclU,请使用 CREATE EXTENSION 命令,例如 CREATE EXTENSION pltclCREATE EXTENSION pltclu

提交更正

如果您在文档中看到任何不正确的内容、与您对特定功能的体验不符的内容或需要进一步说明的内容,请使用此表单 报告文档问题。