加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

在postgresql中使用模式

发布时间:2020-12-13 16:32:29 所属栏目:百科 来源:网络整理
导读:我已经开发了一个使用 postgresql的应用程序,它的工作原理很好. 现在我需要创建同一应用程序的几个实例,但是我只有一个数据库.所以我正在考虑使用模式,以便我可以在不同的模式中对每个实例表进行分组. 现在,我不想重写所有的函数和脚本,所以我想知道我是否可
我已经开发了一个使用 postgresql的应用程序,它的工作原理很好.

现在我需要创建同一应用程序的几个实例,但是我只有一个数据库.所以我正在考虑使用模式,以便我可以在不同的模式中对每个实例表进行分组.

现在,我不想重写所有的函数和脚本,所以我想知道我是否可以使用一些指令来指示数据库在特定模式下运行.只是为了使它更清楚,你知道什么时候你在做什么

using namespace std;

所以你可以使用cout而不是std :: cout?如果可能,我想使用类似的东西.

您要查找的参数是search_path,它列出了查询将要显示的模式.因此,您可以执行以下操作:
CREATE TABLE schema1.tt ...
CREATE TABLE schema2.tt ...
CREATE FUNCTION schema1.foo() ...
CREATE FUNCTION schema2.foo() ...
SET search_path = schema1,something_else;
SELECT * FROM tt;        -- schema1.tt
SELECT * FROM schema2.tt -- schema2.tt
SELECT foo();            -- calls schema1.foo
SELECT schema2.foo();    -- calls schema2.foo

请注意,如果查询的计划被保存在foo()的正文内,那么可能会出现意想不到的结果.如果使用重复的表,我建议您始终在plpgsql函数中明确列出引用表的模式.如果没有,请确保您已经进行了测试,以便使用chaning search_path检查行为.

哦 – 你可以明确地为函数的body设置search_path – 有关详细信息,请参阅手册的CREATE FUNCTION参考.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读