Changed Data Capture (CDC)
Simple is used
for CDC implementation on a single table and Consistent on Multiple tables or
Model.
Simple
CDC – Oracle Table
data:image/s3,"s3://crabby-images/33535/335359c4c8cf48210157416260c141d595577ea4" alt=""
I am going to
implement the Simple CDC concept on this particular table – SRC_AGE_GROUP.
data:image/s3,"s3://crabby-images/a6629/a6629d2167889089168eaf3e6d79a9cd37169c2d" alt=""
Step 1 – Adding
the Table to CDC
data:image/s3,"s3://crabby-images/d2cc2/d2cc2e0e7180b1c5100a627828b626029c804f27" alt=""
data:image/s3,"s3://crabby-images/b8c21/b8c21162425067468248dc51dd46508fa9a8d95b" alt=""
Step 2 – Starting
the journalizing
data:image/s3,"s3://crabby-images/1a3e6/1a3e6c9450739966517b7eb5ad890c5e1d2ed161" alt=""
Select the user
as Subscriber
data:image/s3,"s3://crabby-images/d9920/d9920ae3b08478f568d16c4e2f1abb66eb90769f" alt=""
Execute it
data:image/s3,"s3://crabby-images/cceb8/cceb8f2551da250cadf46d8e1086779da3e83f99" alt=""
The journalizing
process is established.
data:image/s3,"s3://crabby-images/5df59/5df59570ac1eb0f160ae65bf463e6bd482d3c4f8" alt=""
In the above
execution ODI creates a Subscriber table in the work schema, J$ table, view and
a trigger to capture any data changes when any Insert, Update and Deletion
takes places.
After successful
execution you will be able to see a small green clock icon.
data:image/s3,"s3://crabby-images/44488/44488488755b90cc838c17f99292880b0721da5c" alt=""
Let’s do a simple
mapping and test for CDC.
data:image/s3,"s3://crabby-images/fce6e/fce6e1ac6c4f3958a5869959c96438d91a5553b8" alt=""
Drag the
Journalized Table as source and the required target. On the Source Data store,
check mark the option “ JOURNALIZED DATA ONLY “ and ODI will
automatically add a filter with a required date condition and subscriber
information, use the proper LKM and IKM as per your technology. For this
Example I have used IKM Oracle Incremental Update.
I have run it
once to check whether its working fine or not. Now let me show you an example.
Original Source
data:image/s3,"s3://crabby-images/d19a4/d19a41dd50d2c0e3b6000bdf2d0a0212e92c4436" alt=""
Modified source
data:image/s3,"s3://crabby-images/1a534/1a5347466c935ddf10780b1af6e3e1070245417d" alt=""
I have removed
the last column and change the third row age_max 39 to 35.
There are two
ways of seeing Journalized Data.
data:image/s3,"s3://crabby-images/b585c/b585cedacf9b68e26932fde62504e9800cba4470" alt=""
On the
Journalized Interface source and Right click on filter and click on data.
data:image/s3,"s3://crabby-images/0dda1/0dda1a5b5563085505b88ef453bbf1f0d8303d04" alt=""
Here is the sql
from where the journalized data is being retrived
select
* from ODI_TEMP.JV$DSRC_AGE_GROUP SRC_AGE_GROUP where (JRN_SUBSCRIBER =
‘SUNOPSIS’ /* AND JRN_DATE < sysdate */)
The Other way is
to right click on Journalized data store in Model and Changed Data capture –
> Journal Data and you will see the above data again too.
data:image/s3,"s3://crabby-images/37ed5/37ed55ca949cf71b31861ac465b27f6885396625" alt=""
Let’s capture the
Journalized data to my Target table.
Target Table
Before running the Interface
data:image/s3,"s3://crabby-images/8dd14/8dd1486dc963a46116b36ba969a96004bb2c7209" alt=""
As you can see,
one Update and one Deletes.
data:image/s3,"s3://crabby-images/5b309/5b309b0afd215a5b64cb4cf027dad68cbbcdf1fb" alt=""
Target Table
after running the Interface
data:image/s3,"s3://crabby-images/1585e/1585e6d996c073a27a6011320a9cd0aff296130c" alt=""
Repeat the above
steps for Journalizing SQL Server table as we did for Oracle namely
Add to CDC
Start Journal
And if everything
is start the journalizing will start.
data:image/s3,"s3://crabby-images/d0324/d03249ad60e0174c9bae52ff506547ccd996bdfc" alt=""
data:image/s3,"s3://crabby-images/6d855/6d85509783f773e9f53ff601a7630de27295c3c1" alt=""
Source Data before
Running the Journalized Interface
data:image/s3,"s3://crabby-images/917f2/917f261507b73f00bb594361e23490928bcfe379" alt=""
delete from
dimtime_backup where TimeKey=6;
update dimtime_backup set DayNumberOfWeek=4 where TimeKey=4;
update dimtime_backup set DayNumberOfWeek=4 where TimeKey=4;
data:image/s3,"s3://crabby-images/cb966/cb9661bab4273258b98a73797c0dba8200673eec" alt=""
Journalized Data
data:image/s3,"s3://crabby-images/05c06/05c0635d0e1d4319e9164b7089f5ee60b0d69ee5" alt=""
Although there is
update and Delete on the source but there is just delete in the ODI reason
being I have update the same value DayNumberOfWeek=4 again for update so ODI
have correctly did only the Delete as the target already had the same value
which is DayNumberOfWeek=4
data:image/s3,"s3://crabby-images/ba1fa/ba1fa3ff9cc68d959ec787127810047cdc708a48" alt=""
How to say
whether you have which JKM you have , right click on your model ,
Edit –
>Journalizing Tab and you see what JKM is being used and whether Simple or
Consistent
data:image/s3,"s3://crabby-images/646f8/646f89926ea6c647e9767bb3ba9ac32f8d445268" alt=""
data:image/s3,"s3://crabby-images/959e3/959e34e21558cd9e1409d0f4f7a8d2af51d78d35" alt=""
No comments:
Post a Comment