DRY on stg cosmos db models
This commit is contained in:
parent
1c1f8ea82e
commit
3723cf0e57
3 changed files with 33 additions and 46 deletions
|
|
@ -1,29 +1,7 @@
|
|||
with
|
||||
raw_verifications as (select * from {{ source("edeposit", "verifications") }}),
|
||||
deduped_verifications as (
|
||||
select *
|
||||
from
|
||||
-- Some thoughts for the future here:
|
||||
-- ··· The query below is awful performance wise, I know. But data
|
||||
-- size is tiny today. Let's tackle the problem as it comes.
|
||||
--
|
||||
-- ··· The deduping logic below will be the same for all the Cosmos
|
||||
-- DB entities that get brought into the DWH. The only changing
|
||||
-- parameters will be what's the source table and the PK. I'm
|
||||
-- not gonna do the macro now, but it would probably be a good
|
||||
-- idea when we have a second container from Cosmos hitting the
|
||||
-- DWH.
|
||||
(
|
||||
select
|
||||
*,
|
||||
row_number() over (
|
||||
partition by {{ adapter.quote("documents") }} ->> 'id'
|
||||
order by
|
||||
({{ adapter.quote("documents") }} ->> '_ts')::integer desc
|
||||
) as rank
|
||||
from {{ source("edeposit", "verifications") }}
|
||||
)
|
||||
where rank = 1
|
||||
{{ cosmos_db_record_deduplication("raw_verifications", "id") }}
|
||||
),
|
||||
stg_edeposit__verifications as (
|
||||
select
|
||||
|
|
|
|||
|
|
@ -1,29 +1,7 @@
|
|||
with
|
||||
raw_verifications as (select * from {{ source("screening", "verifications") }}),
|
||||
deduped_verifications as (
|
||||
select *
|
||||
from
|
||||
-- Some thoughts for the future here:
|
||||
-- ··· The query below is awful performance wise, I know. But data
|
||||
-- size is tiny today. Let's tackle the problem as it comes.
|
||||
--
|
||||
-- ··· The deduping logic below will be the same for all the Cosmos
|
||||
-- DB entities that get brought into the DWH. The only changing
|
||||
-- parameters will be what's the source table and the PK. I'm
|
||||
-- not gonna do the macro now, but it would probably be a good
|
||||
-- idea when we have a second container from Cosmos hitting the
|
||||
-- DWH.
|
||||
(
|
||||
select
|
||||
*,
|
||||
row_number() over (
|
||||
partition by {{ adapter.quote("documents") }} ->> 'id'
|
||||
order by
|
||||
({{ adapter.quote("documents") }} ->> '_ts')::integer desc
|
||||
) as rank
|
||||
from raw_verifications
|
||||
)
|
||||
where rank = 1
|
||||
{{ cosmos_db_record_deduplication("raw_verifications", "id") }}
|
||||
),
|
||||
stg_screening__verifications as (
|
||||
select
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue