我目前使用Firebird sql作为我的共享软件的db后端,也想支持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 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)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。