dbt-selly/models/generated/airbyte_tables/unibag/product_sku.sql

45 lines
2.1 KiB
SQL

{{ config(
indexes = [{'columns':['_airbyte_emitted_at'],'type':'hash'}],
unique_key = '_airbyte_ab_id',
schema = "unibag",
tags = [ "top-level" ]
) }}
-- Final base SQL model
-- depends_on: {{ ref('product_sku_ab3') }}
select
_id AS id,
sku,
{{ adapter.quote('name') }},
active,
-- quantity,
picture AS photo,
cast({{ adapter.quote('price') }}::json->>'base' AS numeric) AS price_base,
cast({{ adapter.quote('price') }}::json->>'market' AS numeric) AS price_market,
cast({{ adapter.quote('price') }}::json->>'minimum' AS numeric) AS price_min,
cast({{ adapter.quote('price') }}::json->>'maximum' AS numeric) AS price_max,
cast({{ adapter.quote('price') }}::json->>'supplier' AS numeric) AS price_of_supplier,
cast({{ adapter.quote('info') }}::json->'inventory'->>'id' AS integer) AS inventory_code,
{{ adapter.quote('info') }}::json->'inventory'->>'name' AS inventory_name,
{{ adapter.quote('info') }}::json->'supplier'->>'_id' AS supplier_id,
{{ adapter.quote('info') }}::json->'supplier'->>'name' AS supplier_name,
{{ adapter.quote('info') }}::json->>'dimension' AS info_dimension,
unitCode AS info_unit_code,
supplierSku AS supplier_sku,
cast({{ adapter.quote('info') }}::json->>'weight' AS numeric) AS info_weight,
cast({{ adapter.quote('statistic') }}::json->>'saleTotal' AS numeric) AS stats_sale_total,
cast({{ adapter.quote('statistic') }}::json->>'salePending' AS numeric) AS stats_sale_pending,
cast({{ adapter.quote('statistic') }}::json->>'saleDelivered' AS numeric) AS stats_sale_delivered,
cast({{ adapter.quote('statistic') }}::json->>'saleCancelled' AS numeric) AS stats_sale_cancelled,
cast({{ adapter.quote('statistic') }}::json->>'saleCashback' AS numeric) AS stats_sale_cashback,
product AS product_id,
createdat::timestamp AS created_at,
updatedat::timestamp AS updated_at,
_airbyte_ab_id,
_airbyte_emitted_at,
{{ current_timestamp() }} as _airbyte_normalized_at,
_airbyte_product_sku_hashid
from {{ ref('product_sku_ab3') }}
-- product_sku from {{ source('unibag', '_airbyte_raw_product_sku') }}
where 1 = 1