PostgreSQL通过Oracle_FDW连通Oracle实战

📢📢📢📣📣📣

作者:IT邦德

中国DBA联盟(ACDU)成员,15年DBA工作经验

Oracle、PostgreSQL ACE

CSDN博客专家及B站知名UP主,全网粉丝15万+

擅长主流Oracle、MySQL、PG、高斯及Greenplum备份恢复,

安装迁移,性能优化、故障应急处理

文章目录

Oracle_FDW是PostgreSQL的一个外部数据包装器扩展,它遵循SQL/MED(SQL Management of External Data)标准。通过使用此扩展,PostgreSQL可以跨库查询Oracle数据库中的表,甚至执行增删改操作,实现了类似dblink的功能,但通常具有更好的性能和易用性。更重要的是,它可以方便地实现PostgreSQL与Oracle之间的数据同步,为企业的数据整合和迁移提供技术支撑。

1. 下载安装包

从GitHub或PGXN网站下载Oracle_FDW源码包,Oracle_fdw的编译依赖系统中需要有pg_config和Oracle的环境。

Oracle_FDW下载地址

https://pgxn.org/dist/oracle_fdw/

oracle客户端下载地址

https://www.oracle.com/database/technologies/instant-client/linux-x86-64-downloads.html

2. 创建创Oracle环境

复制代码
mkdir /oracle
chown postgres:postgres /oracle
chmod 775 /oracle

--举例解压19C
su - postgres
cd /oracle
unzip /opt/instantclient-basic-linux.x64-19.29.0.0.0dbru.zip -d ./
unzip /opt/instantclient-sdk-linux.x64-19.29.0.0.0dbru.zip -d ./
unzip /opt/instantclient-sqlplus-linux.x64-19.29.0.0.0dbru.zip -d ./

--配置环境变量
vi ~/.bash_profile

export ORACLE_HOME=/oracle/instantclient_19_29
export OCI_LIB_DIR=$ORACLE_HOME
export OCI_INC_DIR=$ORACLE_HOME/sdk/include
export LD_LIBRARY_PATH=$ORACLE_HOME:$LD_LIBRARY_PATH

source .bash_profile

3. 安装ORACLE_FDW插件

unzip /opt/oracle_fdw-2.8.0.zip -d /home/postgres

cd oracle_fdw-2.8.0

make && make install

4.创建外部数据封装器

yum install libnsl

postgres=# CREATE EXTENSION oracle_fdw;

5.创建外部服务器

复制代码
postgres=# create server ora_fdw foreign data wrapper oracle_fdw options(dbserver '192.168.6.10:1521/oradb');

--修改IP及端口
alter server ora_fdw options(set dbserver '192.168.6.10:1521/oradb');

授权使用的用户
grant usage on foreign server ora_fdw to postgres;

创建用户映射,连接oracle的凭证
postgres=# CREATE USER MAPPING FOR postgres SERVER ora_fdw OPTIONS (user 'orauser', password 'oracle');

修改连接用户密码
alter user mapping for postgres server ora_fdw options (set user 'user',set password '**');

6.创建外部表

复制代码
create foreign table fdw_emp(
EMPNO integer options(key 'true') not null,
ENAME varchar(10),
JOB varchar(10),
MGR integer,
HIREDATE date,
SAL numeric(7,2),
COMM numeric(7,2),
DEPTNO integer
) server ora_fdw options (schema 'SCOTT',table 'EMP',readonly 'false');

注:integer OPTIONS (key 'true') NOT NULL是 oracle_fdw插件中用于定义外部表的关键语法,
它主要作用是标识该列映射自 Oracle 源表的主键,
从而启用对 Oracle 数据的修改功能。

readonly:可以限制Oracle表为只读,
不允许INSERT、UPDATE、DELETE操作。

支持一键导入所有表、视图和物化视图

--导入语法:

IMPORT FOREIGN SCHEMA <ora_schema_name>

FROM SERVER <server_name>

INTO <schema_name>

OPTIONS (case 'lower');

7.查看外部表信息

postgres=# select oracle_diag();

postgres=# select oracle_diag();select * from fdw_emp;

增删改外部表,要求一定有主键,外部表主键设置options(key 'true')

复制代码
insert into fdw_emp (empno,ename,job,sal,deptno) values(6666,'IT','DBA',1000,10);
delete from fdw_emp where empno=6666;
update fdw_emp set comm=20000 where empno=7934;

8.其他运维语句

复制代码
-- 查询已创建的到oracle的连接
SELECT * from pg_user_mappings;

-- 删除创建的对象
drop foreign table fdw_emp;
drop user mapping for postgres server ora_fdw;
drop server ora_fdw;
--查看server对象
SELECT * FROM pg_foreign_server;
SELECT s.srvname, w.fdwname, s.srvoptions
FROM pg_foreign_server s
JOIN pg_foreign_data_wrapper w ON w.oid = s.srvfdw;

结语

与传统的ETL工具不同,Oracle_FDW提供了一种"实时"的数据访问方式。当您查询外部表时,PostgreSQL会将查询请求发送给Oracle数据库,在Oracle端执行相应的操作,然后将结果返回给PostgreSQL。这种方式确保您总是获取到最新的数据,而无需进行定期的数据抽取和导入。

相关推荐
茉莉玫瑰花茶3 分钟前
MySQL 存储过程与触发器超详解:从基础到实战(含面试题 + 案例)
数据库·mysql
xiaokangzhe4 分钟前
MySQL故障排查与优化
数据库·mysql
圣光SG4 分钟前
Java类与对象及面向对象基础核心详细笔记
java·前端·数据库
2601_949818098 分钟前
LangChain-08 Query SQL DB 通过GPT自动查询SQL
数据库·sql·langchain
ytttr87310 分钟前
C# 读取数据库表结构工具设计与实现
开发语言·数据库·c#
白露与泡影11 分钟前
从 BIO 到 epoll:高并发 I/O 模型演进与本质分析
java·服务器·数据库
知识分享小能手23 分钟前
MongoDB入门学习教程,从入门到精通,MongoDB副本集的核心机制(11)
数据库·学习·mongodb
一 乐26 分钟前
剧场管理系统|基于springboot + vue剧场管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·剧场管理系统
阿坤带你走近大数据30 分钟前
Oracle里的MINUS是什么
数据库·oracle
佩亚诺余项.32 分钟前
SQL Server 系统视图深度应用:批量检索含关键字的存储过程与数据表字段
数据库