1. 安装oracle_fdw
在编译安装前,需要设置postgres的环境变量,如在.bash_profile中增加:
export ORACLE_HOME=/u01/app/oracle
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$LD_LIBRARY_PATH
export PATH=${PATH}:${ORACLE_HOME}/bin/

--下载 : http://pgxn.org/dist/oracle_fdw/

[root@sdserver40_222 contrib]# unzip oracle_fdw-1.5.0.zip
[root@sdserver40_222 contrib]# cd oracle_fdw-1.5.0
--查看pg_config是否在对应PGHOME/bin目录下。编译后会在对应的目录下面
[root@sdserver40_222 oracle_fdw-1.5.0]# which pg_config
/opt/pgsql/bin/pg_config
[root@sdserver40_222 oracle_fdw-1.5.0]# make
[root@sdserver40_222 oracle_fdw-1.5.0]# make install
[root@sdserver40_222 oracle_fdw-1.5.0]# cd /opt/pgsql/lib
[root@sdserver40_222 lib]# ll oracle_fdw.so
-rwxr-xr-x 1 root root 151893 Oct 18 14:11 oracle_fdw.so
编译成功会在PGHOME/lib目录下会生成 oracle_fdw.so。
2. 创建oracle_fdw外部表
创建oracle_fdw模块需要libclntsh.so.11.1加载库;在$ORACLE_HOME/lib目录下面;
[root@sdserver40_222 lib]# cd /u01/app/oracle/lib/
[root@sdserver40_222 lib]# ll libclntsh.so.11.1
-rwxr-xr-x 1 oracle oinstall 48725761 Jul 26 14:12 libclntsh.so.11.1
[root@sdserver40_222 lib]# cp libclntsh.so.11.1 /opt/pgsql/lib
[root@sdserver40_222 lib]# cd /opt/pgsql/lib
[root@sdserver40_222 lib]# ll libclntsh.so.11.1
-rwxr-xr-x 1 root root 48725761 Oct 18 14:50 libclntsh.so.11.1

在psql中,使用超级用户:

postgres=# create extension oracle_fdw;
CREATE EXTENSION
postgres=# \dx
List of installed extensions
Name | Version | Schema | Description
-------------+---------+------------+----------------------------------------
oracle_fdw | 1.1 | public | foreign data wrapper for Oracle access
pgstattuple | 1.3 | public | show tuple-level statistics
plpgsql | 1.0 | pg_catalog | PL/pgSQL procedural language
 -本次环境测试是;oracle和postgres在同一台服务器上;若不在同一台服务器;postgres服务器需要安装oracle客户端;并配置tnsnames.ora
--下面的 ora229 是来源于$ORACLE_HOME/networks/admin/tnsnames里面的。
--当然也可以使用//oracle-ip/oracle_sid来替换ora229。
postgres=# CREATE SERVER oradb FOREIGN DATA WRAPPER oracle_fdw OPTIONS (dbserver 'ora229');
CREATE SERVER
-- 将server oradb付给用户
postgres=# GRANT USAGE ON FOREIGN SERVER oradb TO lottu;
GRANT
--关联用户(oracle->postgres)
postgres=# CREATE USER MAPPING FOR postgres SERVER oradb OPTIONS (user 'lottu', password 'li0924');
CREATE USER MAPPING
--在oracle服务器创建测试验证表oratab;操作如下:
SQL> select * from oratab;
no rows selected
SQL> insert into oratab select level,'lottu'||level from dual connect by level <=5;
5 rows created.
SQL> commit;
Commit complete.
--这里主要的是oracle跟postgres数据类型不一样时;需要修改下。
--在postgres9.3版本 oracle_fdw支持对外部表的 Insert ,delete ,update ;增加表操作项 options(key 'true') (当值设置为 true|on|yes 表示不可以做增删改操作) 默认值false
postgres=# CREATE FOREIGN TABLE lottu(id int options(key 'true'), name varchar(20)) SERVER oradb OPTIONS (schema 'LOTTU', table 'ORATAB');
CREATE FOREIGN TABLE
postgres=# select * from lottu;
id | name
----+--------
1 | lottu1
2 | lottu2
3 | lottu3
4 | lottu4
5 | lottu5
若出现下面这种问题;原因是出现在OPTIONS (schema 'LOTTU', table 'ORATAB');里面的schema/table需要用大写标注;
借用官方一句话就是“(Remember that table and schema name -- the latter is optional -- must normally be in uppercase.)”
postgres=# select * from oratab;
ERROR: Oracle table "lottu"."oratab" for foreign table "oratab" does not exist or does not allow read access
DETAIL: ORA-00942: table or view does not exist
HINT: Oracle table names are case sensitive (normally all uppercase).
 
3.测试验证
在postgres9.3版本oracle_fdw支持对外部表的 Insert ,delete ,update;这意味着;oracle|postgres都可以对表进行dml操作。这对oracle迁移postgres将会很灵活。
--oracle
SQL> insert into oratab values (1001,'li0924');
1 row created.
SQL> commit;
Commit complete.
--postgres postgres=# delete from lottu where id = 1; DELETE 1 postgres=# select * from lottu; id | name ------+-------- 2 | lottu2 3 | lottu3 4 | lottu4 5 | lottu5 1001 | li0924
【总结】
1. 在postgres9.3版本oracle_fdw支持对外部表的 Insert ,delete ,update;建表添加options(key 'true')这意味着;
oracle|postgres都可以对表进行dml操作。这对oracle迁移postgres将会很灵活。
对postgres是否外部表的 Insert ,delete ,update。oracle_fdw有两个参数可以决定
1. Column options:options (true|on|yes, defaults to "false")
2. table options: readonly (true|on|yes, defaults to "false")
当确定postgres不支持外部表的 Insert ,delete ,update操作;建议使用readonly 'yes';出现的错误提示更亲民些。
例如
postgres=# CREATE FOREIGN TABLE lottu01(id int options(key 'true'), name varchar(20)) SERVER oradb OPTIONS (schema 'LOTTU', table 'ORATAB', readonly 'yes');
CREATE FOREIGN TABLE
postgres=# delete from lottu01 where id = 2;
ERROR: foreign table "lottu01" does not allow deletes
 
2. 外部表支持逻辑备份pg_dump
[postgres@sdserver40_222 ~]$ pg_dump -F p -C -d postgres -f lottu.sql
[postgres@sdserver40_222 ~]$ grep "FOREIGN TABLE" lottu
grep: lottu: No such file or directory
[postgres@sdserver40_222 ~]$ grep "FOREIGN TABLE" lottu.sql
-- Name: lottu; Type: FOREIGN TABLE; Schema: public; Owner: postgres
CREATE FOREIGN TABLE lottu (
ALTER FOREIGN TABLE lottu ALTER COLUMN id OPTIONS (
ALTER FOREIGN TABLE lottu OWNER TO postgres;
-- Name: tab01; Type: FOREIGN TABLE; Schema: public; Owner: postgres
CREATE FOREIGN TABLE tab01 (
ALTER FOREIGN TABLE tab01 ALTER COLUMN id OPTIONS (
ALTER FOREIGN TABLE tab01 OWNER TO postgres;
 

oracle迁移postgres之-oracle_fdw的更多相关文章

  1. oracle迁移postgres之-Ora2Pg

    描述 Ora2Pg:甲骨文PostgreSQL数据库模式转换器是一个免费的工具用于Oracle数据库迁移到PostgreSQL兼容模式.它连接Oracle数据库,扫描它自动提取其结构或数据,然后生成S ...

  2. 阿里云如何打破Oracle迁移上云的壁垒

    2018第九届中国数据库技术大会,阿里云数据库产品专家萧少聪带来以阿里云如何打破Oracle迁移上云的壁垒为题的演讲.Oracle是指“数据库管理系统”,面对Oracle迁移上云的壁垒,阿里云如何能够 ...

  3. 适用MySQL Migration Toolkit 1.0 将oracle迁移到mysql中遇到的问题

    这里主要说一下我在适用中碰到的问题,主要过程参考 http://www.cnblogs.com/duwenlei/p/3520759.html. 首先启动MySQLMigrationTool.exe ...

  4. 使用Microsoft SQL Server Migration Assistant for Oracle迁移数据库

    前言:使用Microsoft SQL Server Migration Assistant for Oracle迁移Oracle数据库到SqlServer数据库. 准备:Oracle11g.SqlSe ...

  5. 使用navicat premium将数据库从Oracle迁移到SQL Server,或从Oracle迁移到MySQL

    有时候我们有迁移数据库的需求,例如从Oracle迁移到SQL Server,或者从MySQL迁移到Oracle. 很多江湖好汉一时不知如何手工操作,所幸的是Navicat提供了迁移的自动化操作界面. ...

  6. Oracle迁移到MySQL性能下降的注意点(转)

    背景:最近有较多的客户系统由原来由Oracle改造到MySQL后出现了性能问题CPU 100%,或是后台的CRM系统复杂SQL在业务高峰的时候出现堆积导致业务故障.在我的记忆里面淘宝最初从Oracle ...

  7. 从Oracle迁移到MySQL的各种坑及自救方案

    当企业内部使用的数据库种类繁杂时,或者有需求更换数据库种类时,都可能会做很多数据迁移的工作.有些迁移很简单,有些迁移可能就会很复杂,大家有没有考虑过为了顺利完成复杂的数据库迁移任务,都需要考虑并解决哪 ...

  8. 怎么将数据库从Oracle迁移到SQL Server,或从Oracle迁移到MySQL

    有时候我们有迁移数据库的需求,例如从Oracle迁移到SQL Server,或者从MySQL迁移到Oracle. 很多江湖好汉一时不知如何手工操作,所幸的是Navicat提供了迁移的自动化操作界面. ...

  9. oracle、postgres、mysql数据库的建库、创建用户、导人导出备份总结

    本文包含的内容:使用命令操作oracle.postgres.mysql的导入导出,登录到数据,创建用户 注:我在公司使用的是Center OS操作系统,所以oracle和postgres均是在Linu ...

随机推荐

  1. DS实验题 融合软泥怪-2 Heap实现

    题目和STL实现:DS实验题 融合软泥怪-1 用堆实现优先队列 引言和堆的介绍摘自:Priority Queue(Heaps)--优先队列(堆) 引言: 优先队列是一个至少能够提供插入(Insert) ...

  2. server与Portal联合,portal许可过期无法登录。

    server与Portal联合,portal许可过期无法登录,怎样解除联合. 解决方案由峥姐友情提供~~ (1)删除有两种方式(①/②选其一即可): ①类似 链接ttps://sunl.esrichi ...

  3. WordPress基础:文章的自定义栏目的使用

    写文章只有标题和内容,那么我想加个加个怎么办呢?这时候就可以用到自定义栏目了,这个功能相当于增加了一个键值对 1.启动“自定义栏目” 2.定义键值对 3.调用自定义栏目值 <?php $pric ...

  4. html5 css3 loading 效果

    canvas  html5load1 主要思路update  实现12个点的绘制和旋转效果 var update = function() { ctx.save();// 把当前绘图状态保存起来 ct ...

  5. sublime text3配置node.js开发环境

    今天配置sublime下node.js网上搜索很多方法. 首先:传统的方法是 1.GIT方法 可直接输入 Git clone https://github.com/tanepiper/SublimeT ...

  6. 【译】SQL Server索引进阶第八篇:唯一索引

    原文:[译]SQL Server索引进阶第八篇:唯一索引     索引设计是数据库设计中比较重要的一个环节,对数据库的性能其中至关重要的作用,但是索引的设计却又不是那么容易的事情,性能也不是那么轻易就 ...

  7. WireShar使用笔记

    1.下载wiresharp  官网下载 2.安装 安装后直接支持中文 很人性化哦 注意:一定要安装WinPcap 不然无法使用 3.

  8. C++求一个十进制的二进制中1的个数

    int oneNumInBinary(int n){ ; while(n){ n = n&(n-); cnt++; } return cnt; }

  9. 转:HAR(HTTP Archive)规范

    HAR(HTTP Archive),是一个用来储存HTTP请求/响应信息的通用文件格式,基于JSON.这个格式的出现可以使HTTP监测工具以一种通用的格式导出所收集的数据,这些数据可以被其他支持HAR ...

  10. 在shell下,用命令将U盘挂载到ubuntu上,并将文件copy到U盘里面

    首先将鼠标定位到ubuntu上,然后插上U盘,这时候先用指令: fidsk -l 查看一下U盘,(这是应该有一个盘符了) 如果没有的话,就尽享下面的步骤: 首先使用命令查看是那个分区,在U盘插入前后, ...