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

时间:2015-01-20 14:34:36

标签: postgresql

我目前使用Firebird SQL作为我的共享软件的数据库后端,也想支持PG 9.3 +。

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

set-context

get-context

e.g。我会在用户登录后执行此操作:

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并做了一些谷歌搜索,但还没有找到解决方案。

会感激任何提示。 沃纳

2 个答案:

答案 0 :(得分:10)

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

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)

答案 1 :(得分:0)

answer 上展开,所以 context() 函数可以同时用作 getter 和 setter,

CREATE OR REPLACE FUNCTION context(text, text default null)
 RETURNS text
 LANGUAGE sql
AS $function$

    select case when $2 is null
        then current_setting($1)
        else set_config($1, $2, false)
    end
    ;
$function$
;

用法:

-- set
select context('USER_SESSION.LANGUAGE_ID', 'lang id');

以后,

-- get
select context('USER_SESSION.LANGUAGE_ID');