小程序制作平台网站设计平台 互联网品牌制作专家
关于A5客户收购GoogleAdsense带有搜索账户的相关事宜更多

软文发布平台资讯中心

PostgreSQL的外部数据封装器fdw用法

PostgreSQL的外部数据封装器fdw用法

  项目招商找A5 快速获取精准代理名单

数据封装器fdw(Foreign Data Wrappers)在PostgreSQL中相当于oracle中的dblink,可以很方便的操作其他数据库中的数据。

场景,在本地的test库中通过外部数据封装器fdw访问本地的testdb中的t2表

本地库test用户u1,远程库test用户dbuser

版本:

postgres=# select version(); version------------------------------------------------------------PostgreSQL 11.1, compiled by Visual C++ build 1914, 64-bit(1 行记录)

1,安装postgres_fdw扩展与授权

1CREATE EXTENSION postgres_fdw;

如果需要授权

1grant usage on foreign data wrapper postgres_fdw to u1;

2,然后使用CREATE SERVER创建一个外部服务器。

CREATE SERVER foreign_server FOREIGN DATA WRAPPER postgres_fdw OPTIONS (host '127.0.0.1', port '5432', dbname 'testdb');

3,用CREATE USER MAPPING 定义的用户映射来标识将在远程服务器上使用的角色:

CREATE USER MAPPING FOR public SERVER foreign_server OPTIONS (user 'dbuser', password '123456');

4,用CREATE FOREIGN TABLE创建外部表了。

在这个例子中我们希望访问远程服务器上名为 some_schema.some_table的表。它的本地名称是 foreign_table,注意结构要对应

CREATE FOREIGN TABLE foreign_table_t2(id int,name varchar(10))SERVER foreign_server options(schema_name 'public',table_name 't2');

这样就可以通过foreign_table_t2来操作远程的表t2了

当然可以使用oracle_fdw,mysql_fdw,tds_fdw,redis_fdw等来操作别的数据库

补充:PostgreSQL数据库插件fdw使用心得—mysql_fdw、oracle_fdw、postgresql_fdw

fdw是foreign data wrapper的一个简称,叫做外部封装数据。

用命令行登陆postgresql:

plsql -h ip地址 -p 端口号 -U 用户名 -d 库名

1、安装fdw

fdw工具是pg自带扩展工具,pg10版本之后不需要再单独安装,一般分为postgresql_fdw、mysql_fdw、file_fdw、oracle_fdw等。可以将不同的异构数据源当成pg的外表。

2、创建库连接

postgresql_fdw

一. 创建postgres_fdw扩展(仅需第一次执行):

-- 创建postgresql_fdw扩展-- Foreign Data Wrapper: postgres_fdwCREATE FOREIGN DATA WRAPPER postgres_fdw -- 删除该扩展-- DROP FOREIGN DATA WRAPPER postgres_fdw

-- 删除该扩展-- DROP FOREIGN DATA WRAPPER postgres_fdw

二. 创建远程服务器,这里需要定义远程主机ip、数据库库名、端口号(同一个远程数据库只需执行一次):

-- 创建ods_server服务对接远程数据库的ods_db库-- Foreign Server: ods_serverCREATE SERVER ods_server FOREIGN DATA WRAPPER postgres_fdw OPTIONS (host '68.26.1.1', dbname 'ods_db', port '5432'); -- 删除该服务 -- DROP SERVER ods_server;

-- 删除该服务 -- DROP SERVER ods_server;

三. 指定连接远程数据库的用户, 和创建的远程服务器一致(同一个远程数据库只需执行一次):

-- 指定连接远程-- User Mapping : xdhCREATE USER MAPPING FOR ods_db SERVER ods_server OPTIONS ("user" 'xha', password '123456'); -- 删除该指定用户-- DROP USER MAPPING FOR creditrisk SERVER cscs

-- 删除该指定用户-- DROP USER MAPPING FOR creditrisk SERVER cscs

四. 在接受数据的pg数据库创建外部表:

CREATE FOREIGN TABLE zha.student( id integer, name varchar(50), age integer, sex varchar(20))SERVER ods_server OPTIONS(schema_name'ods',table_name 'student_ods');-- 将该外表的权限按需要赋权给其它用户GRANT ALL ON TABLE zha.student TO zha;GRANT SELECT ON TABLE zha.student TO zhb;

Materialized View 物化视图

五. 可将外部表映射成pg的物化视图,以便进行数据查询等(同一张表只需执行一次):

-- Materialized View: gzk.student-- DROP MATERIALIZED VIEW gzk.student;CREATE MATERIALIZED VIEW gzk.studentAS SELECT id, name, age, sex from zha.student;

六. 刷新物化视图的数据:

普通视图的数据只是一个select,可以随原表数据的变化而变化,但物化视图类似于一个真正的表,可以创建索引,数据不会随着原表的变化而变化,需要手动刷新数据。

-- 全量刷新(先清空表再重新映射数据,刷新时阻塞select! 较快!)refresh materialized view gzk.student;-- 增量刷新(全表数据对比更新,刷新时不会阻塞select! 较慢!)-- 只有当物化视图中存在unique index(唯一索引)的时候,-- refresh物化视图才能使用增量更新,加入concurrently参数。否则报错。refresh materiallized view concurrently gzk.student;-- 报错-- ERROR: cannot refresh materialized view "gzk.student" concurrently-- HINT: Create a unique index with no WHERE clause on one -- or more columns of the materialized view.-- 在物化视图上创建unique index(唯一索引,可以以自增主键id为唯一索引)create unique index uidx_mv_id on gzk.student(id);refresh materiallized view concurrently gzk.student;-- 执行成功-- 实际业务中可选增量刷新,定时执行refresh的方式

七. 可以把物化视图刷新sql放到pgAgent job里, 定时刷新数据.

八. mysql_fdw、oracle_fdw、file_fdw用法类似,不做赘述。

文章来源:脚本之家

来源地址:https://www.jb51.net/article/204330.htm

尊敬的看官您对PostgreSQL的外部数据封装器fdw用法有什么看法呢?互联网品牌制作专家愿与您共同探讨!版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请加微信号oem365 举报,一经查实,本站将立刻删除。

上一篇: postgresql查看表和索引的情况,判断是否膨胀的操作   返 回   下一篇:PostgreSQL中的postgres_fdw扩展详解

相关资讯

小程序应用场景 | 小程序解决方案 | 小程序案例 | 小程序应功能 | 软文发布资源 | 网站设计

酒店预约解决方案
酒店预约小程序走红网络,也是传统转型的重要变化
详情
投票解决方案
强大功能,傻瓜式管理,有效防止作弊刷票
详情
新零售解决方案
小程序是现在新零售的新方式,深度结合线上线下
详情
预约服务解决方案
预约到店小程序通过用户在线预约到店等
详情
企业官网解决方案
企业展示小程序主要展示企业信息、产品案例等
详情
教育培训解决方案
主要展示教育机构的课程、可在线预约与购买课程
详情
推广解决方案
可以让企业通过推广模式全面展示自己的产品
详情
到店解决方案
到店服务解决方案,主要是面向实体餐饮门店
详情

我们的服务是否能满足您的需求?

如果不能,请联系我们或给我们留言,我们收到后会第一时间联系您!感谢您对我们的关注!

粤公网安备 44200002005005号