postgresql – 如何为用户/连接设置一些上下文变量
发布时间:2020-12-13 16:05:49 所属栏目:百科 来源:网络整理
导读:我目前使用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
我目前使用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) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |