暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

【翻译PG】43.11. PL/Tcl配置

seagull 2024-12-31
45

43.11. PL/Tcl配置

这一节列举影响的配置参数。

如果被设置为一个非空字符串,这个参数指定一个无参数PL/Tcl函数的名称(可能是方案限定的),只要为PL/Tcl创建一个新的Tcl解释器,就会执行这个函数。这样一个函数可以执行针对会话的初始化,例如载入额外的Tcl代码。当一个PL/Tcl在一个数据库会话中被第一次执行时,或者由于一个PL/Tcl函数被一个新的SQL角色调用而必须创建一个额外的解释器时,一个新的Tcl解释器会被创建。

被引用的函数必须用pltcl语言编写,并且不能被标记为SECURITY DEFINER(这些限制确保它运行在它应该要初始化的解释器中)。当前用户也必须有权限调用它。

如果该函数带着一个错误失败,它将中止导致新解释器创建的函数并且把错误传播到调用查询,进而导致当前事务或子事务被中止。在Tcl中已完成的任何动作将不会被撤销,不过,那个解释器将不会被再次使用。如果该语言被再次使用,则初始化将在一个全新的Tcl解释器中被再次尝试。

只有超级用户能够更改这个设置。尽管这个设置能在会话中更改,但这种更改将不会影响已经被创建的Tcl解释器。

这个参数与pltcl.start_proc几乎一模一样,只不过它适用于PL/TclU。被引用的函数必须用pltclu语言编写。


「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论