Skip to content

Latest commit

 

History

History
58 lines (46 loc) · 1.68 KB

README.md

File metadata and controls

58 lines (46 loc) · 1.68 KB

Intro

All the oracle client library and FDW extention is in the sdk bacause is not possbile to get it through wget from Oracle site. If you need another version download it from Oracle site an put it into sdk folder.

Build image

docker build -t postgres_ora_fdw_plv8 .

Supported args

Arg default
postgres_version 12
oracle_fdw_version 2_2_1
instantclient_version 19_3

Run image

mkdir -p /opt/postgres/data

docker pull huanglg/oracle_fdw_plv8:v4
docker run -d --name postgres -p 5432:5432 -e POSTGRES_PASSWORD=postgres --restart=always -v  /opt/postgres/data:/var/lib/postgresql/data huanglg/oracle_fdw_plv8:v4

Create Foreign Data Wrapper

Enter into container

docker exec -it test-postgres bash

then

psql

then create the extension and the connection to remote DB

CREATE EXTENSION oracle_fdw;
CREATE SERVER oradb FOREIGN DATA WRAPPER oracle_fdw
          OPTIONS (dbserver '//<host>:1521/<database>');
GRANT USAGE ON FOREIGN SERVER oradb TO postgres;
CREATE USER MAPPING FOR postgres SERVER oradb OPTIONS (user 'user', password 'password');

# you can alter foreign data wrapper
ALTER SERVER oradb
    OPTIONS (ADD isolation_level 'read_committed');

then import table (this is like creating a symbolic link to remote database, no data is imported)

IMPORT FOREIGN SCHEMA "<foreignSchemaName>"
    FROM SERVER oradb
    INTO <localSchemaName>;

more info on PostgreSQL docs.