首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Postgresql会话的自定义参数

Postgresql会话的自定义参数
EN

Stack Overflow用户
提问于 2014-08-14 17:55:32
回答 2查看 1.8K关注 0票数 1

为了在PostgreSQL DB中记录表数据更改,我在UPDATE和INSERT上创建了table触发器,然而,除了有更改的触发器之外,我还想知道是谁更改了它,但是站点代码使用一个"DB用户“连接到DB,我可以通过CURRENT_USER变量获得它。如何将一些参数(“site user”name)附加到DB会话中,这样以后我就可以在触发器函数中将其放入DB。在网站上,我使用的是SQLAlchemy。

EN

回答 2

Stack Overflow用户

发布于 2014-08-14 18:55:05

很抱歉,我正在回答我的问题,但我刚刚找到了另一个使用自定义选项http://www.postgresql.org/docs/9.3/static/runtime-config-custom.html的解决方案

在postgresql.conf中添加

如果是>= 9.2版

代码语言:javascript
运行
复制
site.user = NULL

如果是<= 9.1版

代码语言:javascript
运行
复制
custom_variable_classes = 'site'
site.user = NULL 

然后在事务的范围内

代码语言:javascript
运行
复制
SELECT SET_CONFIG('site.user', 'user name', true); 
...
SELECT INTO site_user CURRENT_SETTING('site.user'); 
票数 2
EN

Stack Overflow用户

发布于 2014-08-14 18:36:40

在PostgreSQL中没有本机方法可以做到这一点。一种选择可能是修改数据库连接代码(客户端),以便在每次连接时在数据库会话中设置该信息:

代码语言:javascript
运行
复制
CREATE TEMPORARY TABLE active_user (site_user VARCHAR);
INSERT INTO active_user (site_user) VALUES (?);

然后在稍后的触发器中:

代码语言:javascript
运行
复制
...
DECLARE site_user VARCHAR;
...
   SELECT INTO site_user site_user FROM active_user
...
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25305194

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档