postgresql – 如何为用户/连接设置一些上下文变量

我目前使用Firebird sql作为我的共享软件的db后端,也想支持PG 9.3.

在FB中我使用set / get_context来执行此操作:

set-context

get-context

例如我会在用户登录后执行此操作:

select rdb$set_context('USER_SESSION','LANGUAGE_ID',%s) \
        from rdb$database" % appobj.loggedInUser.language.id

在我的一些观点中,我将使用:

... AND t.fk_language_id=rdb$get_context('USER_SESSION','LANGUAGE_ID')

搜索了PG doc并做了一些谷歌搜索,但还没有找到解决方案.

非常感谢任何提示.
维尔纳

解决方法

您可以在自定义架构中使用会话变量:

postgres=# set myvars.language_id = 10;
SET
postgres=# show myvars.language_id;
 myvars.language_id 
--------------------
 10
(1 row)

或通过功能(http://www.postgresql.org/docs/9.4/static/functions-admin.html):

postgres=# select set_config('myvars.language_id','20',false);
 set_config 
------------
 20
(1 row)

postgres=# select current_setting('myvars.language_id');
 current_setting 
-----------------
 20
(1 row)

相关文章

项目需要,有个数据需要导入,拿到手一开始以为是mysql,结果...
本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表...
错误现象问题原因这是在远程连接时pg_hba.conf文件没有配置正...
因本地资源有限,在公共测试环境搭建了PGsql环境,从数据库本...
wamp 环境 这个提示就是说你的版本低于10了。 先打印ph...
psycopg2.OperationalError: SSL SYSCALL error: EOF detect...