ETL+ Load Upsert Example 2
Simple Upsert example. No deleted source records, no changes to key.
ETL Configuration
data:image/s3,"s3://crabby-images/cbcf6/cbcf6c5eadc56540104825637879e8a934130fae" alt=""
Load Upsert panel.
Sequence is the highwater column
data:image/s3,"s3://crabby-images/dc0f2/dc0f2a2873a4a51fda5fbc0b012d1751d8b952e8" alt=""
See Load Upsert panel lower right.
data:image/s3,"s3://crabby-images/70728/70728b1fde22c5aaa768e799a19b77cdcef8220d" alt=""
key column marked as the Key+ column.
For upsert processing the column(s) marked as Key+ function as a logical unique key.
Initial Load Upsert
Data Source
Target Table After Initial Load Upsert
data:image/s3,"s3://crabby-images/f9366/f9366b04fbba54f4c13975d809115d8e0e3b93ca" alt=""
ETL+ Preview page
data:image/s3,"s3://crabby-images/65649/6564934262b3bf571bf272708223e44db3c2471f" alt=""
From SSMS,
highwater mark in Sequence column after Load Upsert is 104
ETL Log: (4 rows loaded)
2nd Load Upsert
The first step of the upsert process extracts the highwater mark from the target table. In this example the highwater mark is before the from Sequence column in target table before Upsert is 104
.
Before: The highwater mark is 104
. (See Sequence column in Target Table after step above)
Data Source
Target Table After 2nd Upsert
data:image/s3,"s3://crabby-images/c7052/c7052a104e99f731f8e5d31aaced6ad153973f1c" alt=""
1st row changed to
Sequence = 105
data:image/s3,"s3://crabby-images/5d456/5d4562cb53a63b57b9961e1b7b516c0495a964e0" alt=""
Data from SSMS,
new highwater mark is 105
ETL Log: (2 rows upserted)
Alternative View:
data:image/s3,"s3://crabby-images/65649/6564934262b3bf571bf272708223e44db3c2471f" alt=""
Target table before 2nd Upsert
data:image/s3,"s3://crabby-images/c7052/c7052a104e99f731f8e5d31aaced6ad153973f1c" alt=""
Source data for 2nd Upsert
data:image/s3,"s3://crabby-images/5d456/5d4562cb53a63b57b9961e1b7b516c0495a964e0" alt=""
Target Table after 2nd Upsert
Target Table in Database
Included for those interested. Very few users need to know the internals of the database tables storing the data warehouse.
data:image/s3,"s3://crabby-images/42c48/42c481743b8c4a006fd8e48c410620240bdc49ee" alt=""