PostgreSQL 8.0.0 中文文档(PostgreSQL 中国制作) | ||||
---|---|---|---|---|
Prev | Fast Backward | Chapter 36. PL/Tcl - Tcl 过程语言 | Fast Forward | Next |
有时候在两次过程函数调用或者不同的函数之间保存一些全局数据是非常有用的。 因为所有在一个后端运行的PL/Tcl过程共享同一个安全 Tcl 解释器。 所以实现这个目标相当容易。 因此,任何全局 Tcl 变量都是可以被所有PL/Tcl过程调用访问的, 并且将在该次 SQL 会话过程中保持一致。(请注意PL/TclU函数也类似地共享全局数据, 但是它们在一个不同的 Tcl 解释器里并且无法和PL/Tcl函数通讯。)
为了保护 PL/Tcl 过程相互之间不至于互相干扰, 每个过程可以通过upvar命令访问一个全局数组。 此变量的全局名称是过程的内部名称,其局部名称是GD。 我们建议使用 GD 作为函数的永久私有状态数据的存储。 而把普通的 Tcl 全局变量只用于那些你想在多个过程之间共享的变量。
一个使用 GD 的例子在下面的 spi_execp 例子里显示。