我目前使用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
Run Code Online (Sandbox Code Playgroud)
在我的一些观点中,我将使用:
... AND t.fk_language_id=rdb$get_context('USER_SESSION', 'LANGUAGE_ID')
Run Code Online (Sandbox Code Playgroud)
我搜索了PG doc并做了一些谷歌搜索,但还没有找到解决方案.
非常感谢任何提示.维尔纳
Pav*_*ule 12
您可以在自定义架构中使用会话变量:
postgres=# set myvars.language_id = 10;
SET
postgres=# show myvars.language_id;
myvars.language_id
--------------------
10
(1 row)
Run Code Online (Sandbox Code Playgroud)
或通过功能(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)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6286 次 |
| 最近记录: |