如何为 user/connection 设置一些上下文变量
How to set some context variable for a user/connection
我目前使用 Firebird SQL 作为我的共享软件的数据库后端,希望也支持 PG 9.3+。
在 FB 中,我使用 set/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 文档并进行了一些谷歌搜索,但还没有找到解决方案。
如有任何提示,我们将不胜感激。
维尔纳
您可以在自定义架构中使用会话变量:
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)
扩展 ,因此 context()
函数可以用作 getter 和 setter,
CREATE OR REPLACE FUNCTION context(text, text default null)
RETURNS text
LANGUAGE sql
AS $function$
select case when is null
then current_setting()
else set_config(, , false)
end
;
$function$
;
用法:
-- set
select context('USER_SESSION.LANGUAGE_ID', 'lang id');
以后,
-- get
select context('USER_SESSION.LANGUAGE_ID');
我目前使用 Firebird SQL 作为我的共享软件的数据库后端,希望也支持 PG 9.3+。
在 FB 中,我使用 set/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 文档并进行了一些谷歌搜索,但还没有找到解决方案。
如有任何提示,我们将不胜感激。 维尔纳
您可以在自定义架构中使用会话变量:
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)
扩展 context()
函数可以用作 getter 和 setter,
CREATE OR REPLACE FUNCTION context(text, text default null)
RETURNS text
LANGUAGE sql
AS $function$
select case when is null
then current_setting()
else set_config(, , false)
end
;
$function$
;
用法:
-- set
select context('USER_SESSION.LANGUAGE_ID', 'lang id');
以后,
-- get
select context('USER_SESSION.LANGUAGE_ID');