44.11. PL/Tcl 配置#
本节列出了影响PL/Tcl的配置参数。
pltcl.start_proc
(string
) #如果此参数设置为非空字符串,则指定一个无参数 PL/Tcl 函数的名称(可能包含架构限定),该函数将在为 PL/Tcl 创建新的 Tcl 解释器时执行。此类函数可以执行每个会话的初始化,例如加载其他 Tcl 代码。当 PL/Tcl 函数首次在数据库会话中执行时,或者当需要创建其他解释器时(因为 PL/Tcl 函数由新的 SQL 角色调用),将创建一个新的 Tcl 解释器。
引用的函数必须用
pltcl
语言编写,并且不得标记为SECURITY DEFINER
。(这些限制确保它在它应该初始化的解释器中运行。)当前用户也必须有权调用它。如果函数因错误而失败,它将中止导致创建新解释器的函数调用,并传播到调用查询,从而导致中止当前事务或子事务。在 Tcl 中已执行的任何操作都不会撤消;但是,该解释器将不再使用。如果再次使用该语言,将在新的 Tcl 解释器中再次尝试初始化。
只有超级用户才能更改此设置。尽管此设置可以在会话中更改,但此类更改不会影响已创建的 Tcl 解释器。
pltclu.start_proc
(string
) #此参数与
pltcl.start_proc
完全相同,但它适用于 PL/TclU。引用的函数必须用pltclu
语言编写。