Sunday, December 14, 2014

Highlighting xDB Replication Server

This is the first in a series of posts highlighting common business requirements for managing data I see in the field, and the tools that are available to help meet those requirements.

One common requirement many organizations have is being able to move data around to different database systems. While I deal with a lot of requests for help moving data from Oracle to Postgres, I also assist businesses that routinely push data from Postgres to Oracle. Typically because the corporate BI database is still on Oracle.

This post captures a simple use-case that I encounter often. "We need to move data in Postgres to a staging table in our Oracle BI database." For a job such as this one, no custom scripts are necessary - xDB from EnterpriseDB is the perfect tool.


I can verify the tables do not already exist in Oracle by querying with a oci-dblink connection from Postgres.

edbstore=# select * from cat@edbstore_ora;
 table_name | table_type
------------+------------
(0 rows)

Let's describe the tables in our edbstore database. These tables should look familiar if you've ever taken one of EnterpriseDB's training courses.                               
edbstore=# \dt+
                          List of relations
  Schema  |    Name    | Type  |  Owner   |    Size    | Description
----------+------------+-------+----------+------------+-------------
 edbstore | categories | table | edbstore | 8192 bytes |
 edbstore | cust_hist  | table | edbstore | 2640 kB    |
 edbstore | customers  | table | edbstore | 3936 kB    |
 edbstore | dept       | table | edbstore | 8192 bytes |
 edbstore | emp        | table | edbstore | 8192 bytes |
 edbstore | inventory  | table | edbstore | 464 kB     |
 edbstore | job_grd    | table | edbstore | 16 kB      |
 edbstore | jobhist    | table | edbstore | 8192 bytes |
 edbstore | locations  | table | edbstore | 8192 bytes |
 edbstore | orderlines | table | edbstore | 3104 kB    |
 edbstore | orders     | table | edbstore | 920 kB     |
 edbstore | products   | table | edbstore | 832 kB     |
 edbstore | reorder    | table | edbstore | 0 bytes    |
(13 rows)

Now I'm going to add the edbstore database to our xDB Publication Server.



Next, I'm adding the Oracle target database to the Subscription server using the xDB Replication Console. 



A Publication can be created with the xDB Replication Console. In this case we are only interested in the  customers and orders table. 
Note: Click on the Table Filters tab if you need to add a filter.



Now we can move over the the Subscription Server and subscribe to the newly created Publication from within the same console.




Take a Snapshot.



The Data Load and Migration Summary will be displayed toward the end of the console messages:
[orders] Table Data Load Summary: Total Time(s): 6.379 Total Rows: 12000
Data Load Summary: Total Time (sec): 14.398 Total Rows: 32000 Total Size(MB): 0.0

Schema edbstore imported successfully.

Let's verify the data is in Oracle using SQL*Plus                                                
SQL> select
  2  (select count(*) from customers) AS customers_count,
  3  (select count(*) from orders) AS orders_count
  4  from dual;

CUSTOMERS_COUNT ORDERS_COUNT
--------------- ------------
 20000        12000

Configure Synchronization to whatever schedule suits your needs.                                            
Synchronization can be configured as Daily, Weekly, Monthly or a Cron Expression. Let's go with Continuously. 


From the xDB Replication Console:






Verify that changes are immediately being replicated to the target Oracle Database.
I'm going to COPY 50 records into the Orders table in Postgres and verify the updates are immediately available in Oracle as well.

edbstore=# select
edbstore-# (select count(*) from orders) AS orders_postgres,
edbstore-# (select count(*) from orders@edbstore_ora) AS orders_oracle
edbstore-# from dual;
 orders_postgres | orders_oracle
-----------------+---------------
           12050 |         12050
(1 row)



                                   

No comments:

Post a Comment