diff --git a/.github/ISSUE_TEMPLATE/bug_report.md b/.github/ISSUE_TEMPLATE/bug_report.md deleted file mode 100644 index 92604ced1..000000000 --- a/.github/ISSUE_TEMPLATE/bug_report.md +++ /dev/null @@ -1,30 +0,0 @@ ---- -name: Bug report -about: Create a report to help us improve -title: "[BUG] " -labels: bug -assignees: DVAlexHiggs - ---- - -**Describe the bug** -A clear and concise description of what the bug is. - -**To Reproduce** -Steps to reproduce the behavior: -1. Go to '...' -2. Click on '....' -3. Scroll down to '....' -4. See error - -**Expected behavior** -A clear and concise description of what you expected to happen. - -**Screenshots** -If applicable, add screenshots to help explain your problem. - -**Log files** -If applicable, provide dbt log files which include the problem. - -**Additional context** -Add any other context about the problem here. diff --git a/.github/ISSUE_TEMPLATE/feature_request.md b/.github/ISSUE_TEMPLATE/feature_request.md deleted file mode 100644 index 3448c4715..000000000 --- a/.github/ISSUE_TEMPLATE/feature_request.md +++ /dev/null @@ -1,20 +0,0 @@ ---- -name: Feature request -about: Suggest an idea for this project -title: "[FEATURE] " -labels: '' -assignees: DVAlexHiggs - ---- - -**Is your feature request related to a problem? Please describe.** -A clear and concise description of what the problem is. Ex. I'm always frustrated when [...] - -**Describe the solution you'd like** -A clear and concise description of what you want to happen. - -**Describe alternatives you've considered** -A clear and concise description of any alternative solutions or features you've considered. - -**Additional context** -Add any other context or screenshots about the feature request here. diff --git a/.gitignore b/.gitignore deleted file mode 100644 index 45ddf0ae3..000000000 --- a/.gitignore +++ /dev/null @@ -1 +0,0 @@ -site/ diff --git a/README.md b/README.md index 27abae1fc..d1921566e 100644 --- a/README.md +++ b/README.md @@ -1,14 +1,8 @@ -### News - - * We now have a slack channel, use the button below to join - * Looking to use dbtvault or Data Vault in your project? We've written a document to give you a head start. - Download for FREE now! -
-[![Documentation Status](https://readthedocs.org/projects/dbtvault/badge/?version=latest)](https://dbtvault.readthedocs.io/en/latest/?badge=latest) +[![Documentation Status](https://readthedocs.org/projects/dbtvault/badge/?version=stable)](https://dbtvault.readthedocs.io/en/latest/?badge=stable) [![Join our Slack](https://img.shields.io/badge/Slack-Join-yellow?style=flat&logo=slack)](https://join.slack.com/t/dbtvault/shared_invite/enQtODY5MTY3OTIyMzg2LWJlZDMyNzM4YzAzYjgzYTY0MTMzNTNjN2EyZDRjOTljYjY0NDYyYzEwMTlhODMzNGY3MmU2ODNhYWUxYmM2NjA) @@ -69,12 +63,20 @@ And run var('src_source'), var('source')) }} ``` +## Join our Slack Channel + +Talk to our developers and other members of our growing community, get support and discuss anything related to dbtvault or Data Vault 2.0 + +[![Join our Slack](https://img.shields.io/badge/Slack-Join-yellow?style=flat&logo=slack)](https://join.slack.com/t/dbtvault/shared_invite/enQtODY5MTY3OTIyMzg2LWJlZDMyNzM4YzAzYjgzYTY0MTMzNTNjN2EyZDRjOTljYjY0NDYyYzEwMTlhODMzNGY3MmU2ODNhYWUxYmM2NjA) + ## Sign up for early-bird announcements [![Sign up](https://img.shields.io/badge/Email-Sign--up-blue)](https://www.data-vault.co.uk/dbtvault/) Get notified of new features and new releases before anyone else! +## Starting a Data Vault project + ## Contributing [View our contribution guidelines](CONTRIBUTING.md) diff --git a/dbt_project.yml b/dbt_project.yml index 03ad7784e..a01723977 100644 --- a/dbt_project.yml +++ b/dbt_project.yml @@ -4,7 +4,7 @@ require-dbt-version: [">=0.14.0", "<0.17.0"] profile: 'dbtvault' -source-paths: ["models"] +source-paths: ["models", "models_test"] analysis-paths: ["analysis"] test-paths: ["tests"] data-paths: ["data"] diff --git a/macros/internal/alias.sql b/macros/internal/alias.sql new file mode 100644 index 000000000..0e43c73e2 --- /dev/null +++ b/macros/internal/alias.sql @@ -0,0 +1,53 @@ +{#- Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +-#} +{%- macro alias(source_column=none, prefix=none) -%} + +{%- if source_column -%} + + {%- if source_column is iterable and source_column is not string -%} + + {%- if source_column['source_column'] and source_column['alias'] -%} + + {%- if prefix -%} + {{prefix}}.{{ source_column['source_column'] }} AS {{ source_column['alias'] }} + {%- else -%} + {{ source_column['source_column'] }} AS {{ source_column['alias'] }} + {%- endif -%} + + {%- endif -%} + + {%- else -%} + + {%- if prefix -%} + + {{- dbtvault.prefix([source_column], prefix) -}} + + {%- else -%} + + {{ source_column }} + + {%- endif -%} + + {%- endif -%} + +{%- else -%} + + {%- if execute -%} + + {{ exceptions.raise_compiler_error("Invalid alias configuration:\nexpected format: {source_column: 'column', alias: 'column_alias'}\ngot: " ~ source_column) }} + + {%- endif -%} + +{%- endif -%} + +{%- endmacro -%} \ No newline at end of file diff --git a/macros/internal/single.sql b/macros/internal/alias_all.sql similarity index 69% rename from macros/internal/single.sql rename to macros/internal/alias_all.sql index 95e3cf2c4..6bfd74557 100644 --- a/macros/internal/single.sql +++ b/macros/internal/alias_all.sql @@ -10,11 +10,15 @@ See the License for the specific language governing permissions and limitations under the License. -#} +{%- macro alias_all(columns, prefix) -%} -{%- macro single(src_pk, src_nk, src_ldts, src_source, - source, letter='a') -%} +{%- if columns is iterable and columns is not string -%} - SELECT {{ dbtvault.prefix([src_pk, src_nk, src_ldts, src_source], letter) }} - FROM {{ source }} AS {{ letter }} + {%- for column in columns -%} + {{ dbtvault.alias(column, prefix) }} + {%- if not loop.last -%} , {% endif -%} + {%- endfor -%} + +{%- endif -%} {%- endmacro -%} \ No newline at end of file diff --git a/macros/staging/from.sql b/macros/internal/as_constant.sql similarity index 65% rename from macros/staging/from.sql rename to macros/internal/as_constant.sql index 3b9608d79..7a4304d9f 100644 --- a/macros/staging/from.sql +++ b/macros/internal/as_constant.sql @@ -10,9 +10,19 @@ See the License for the specific language governing permissions and limitations under the License. -#} +{%- macro as_constant(column_str) -%} -{% macro from(source_table) %} + {% if column_str is not none %} -FROM {{ source_table }} + {%- if column_str | first == "!" -%} + + {{- return("'" ~ column_str[1:] ~ "'") -}} + + {%- else -%} + + {{- return(column_str) -}} + + {%- endif -%} + {%- endif -%} {%- endmacro -%} \ No newline at end of file diff --git a/macros/internal/docs/internal_macros.md b/macros/internal/docs/internal_macros.md new file mode 100644 index 000000000..6b8bbc6f3 --- /dev/null +++ b/macros/internal/docs/internal_macros.md @@ -0,0 +1,5 @@ +{%- docs macro_alias -%} + +. + +{%- enddocs %} \ No newline at end of file diff --git a/macros/internal/docs/internal_macros_schema.yml b/macros/internal/docs/internal_macros_schema.yml new file mode 100644 index 000000000..fa75207f8 --- /dev/null +++ b/macros/internal/docs/internal_macros_schema.yml @@ -0,0 +1,10 @@ +version: 2 + +macros: + - name: alias + description: "{{ doc('macro_alias') }}" + + arguments: + - name: src_pk + type: string + description: "" \ No newline at end of file diff --git a/macros/internal_deprecated/get_col_list.sql b/macros/internal/expand_column_list.sql similarity index 51% rename from macros/internal_deprecated/get_col_list.sql rename to macros/internal/expand_column_list.sql index c1dc53a04..2420a2f42 100644 --- a/macros/internal_deprecated/get_col_list.sql +++ b/macros/internal/expand_column_list.sql @@ -11,32 +11,41 @@ limitations under the License. -#} -{%- macro get_col_list(tgt_cols) -%} +{%- macro expand_column_list(columns=none) -%} +{%- if not columns -%} + {%- if execute -%} + {{ exceptions.raise_compiler_error("Expected a list of columns, got: " ~ columns) }} + {%- endif -%} +{%- endif -%} {%- set col_list = [] -%} -{%- if tgt_cols is iterable -%} +{%- if columns is iterable -%} - {%- for columns in tgt_cols -%} + {%- for col in columns -%} - {%- if columns is string -%} + {%- if col is string -%} - {%- set _ = col_list.append(columns) -%} + {%- set _ = col_list.append(col) -%} - {#- If a triple -#} - {%- elif columns | first is string -%} + {#- If list of lists -#} + {%- elif col is iterable and col is not string -%} - {%- set _ = col_list.append(columns|last) -%} + {%- if col is mapping -%} - {#- If list of lists -#} - {%- elif columns is iterable and columns is not string -%} + {%- set _ = col_list.append(col) -%} + + {%- else -%} + + {%- for cols in col -%} + + {%- set _ = col_list.append(cols) -%} - {%- for cols in columns -%} + {%- endfor -%} - {%- set _ = col_list.append(cols|last) -%} + {%- endif -%} - {%- endfor -%} {%- endif -%} {%- endfor -%} diff --git a/macros/internal/get_src_col_list.sql b/macros/internal/get_src_col_list.sql deleted file mode 100644 index c38908ecd..000000000 --- a/macros/internal/get_src_col_list.sql +++ /dev/null @@ -1,41 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro get_src_col_list(tgt_cols) -%} - -{%- set col_list = [] -%} - -{%- if tgt_cols is iterable -%} - - {%- for columns in tgt_cols -%} - - {%- if columns is string -%} - - {%- set _ = col_list.append(columns) -%} - - {#- If list of lists -#} - {%- elif columns is iterable and columns is not string -%} - - {%- for cols in columns -%} - - {%- set _ = col_list.append(cols) -%} - - {%- endfor -%} - {%- endif -%} - - {%- endfor -%} -{%- endif -%} - -{{ return(col_list) }} - -{%- endmacro -%} \ No newline at end of file diff --git a/macros/internal/hash_check.sql b/macros/internal/hash_check.sql deleted file mode 100644 index 335e82354..000000000 --- a/macros/internal/hash_check.sql +++ /dev/null @@ -1,24 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro hash_check(hash) -%} - -{%- if hash == 'MD5' %} -MD5_BINARY('^^') -{%- elif hash == 'SHA' %} -SHA2_BINARY('^^') -{%- else %} -MD5_BINARY('^^') -{% endif %} - -{% endmacro %} \ No newline at end of file diff --git a/macros/internal/is_multi_source.sql b/macros/internal/is_multi_source.sql deleted file mode 100644 index 0e836af27..000000000 --- a/macros/internal/is_multi_source.sql +++ /dev/null @@ -1,41 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro is_multi_source(source, src_pk, src_fk, src_ldts, src_source) -%} - -{%- if source is iterable and source is not string -%} - {%- set multi_source = [] -%} - {%- for element in source -%} - - {%- set _ = multi_source.append(ref(element)) -%} - - {%- endfor -%} - - {%- set is_union = dbtvault.is_union(multi_source) -%} - {%- set source_col = dbtvault.source_columns(src_pk, src_fk, src_ldts, src_source, - multi_source, is_union) -%} - - {{- return([source_col, is_union]) -}} - -{%- else -%} - - {%- set source = [ref(var('source'))] -%} - {%- set is_union = dbtvault.is_union(source) -%} - {%- set source_col = dbtvault.source_columns(src_pk, src_fk, src_ldts, src_source, - source, is_union) -%} - - {{- return([source_col, is_union]) -}} - -{%- endif -%} - -{%- endmacro -%} \ No newline at end of file diff --git a/macros/internal/is_union.sql b/macros/internal/is_union.sql deleted file mode 100644 index cfd004d84..000000000 --- a/macros/internal/is_union.sql +++ /dev/null @@ -1,49 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro is_union(obj) -%} - -{%- if obj is iterable and obj is not string -%} - {%- set checked_relations = [] -%} - {%- for source in obj -%} - {%- set _ = checked_relations.append(dbtvault.check_relation(source)) -%} - {%- endfor -%} - - {#- Not a union if only one source -#} - {%- if checked_relations | length == 1 -%} - - {{- return(false) -}} - - {%- else -%} - {#- Check all are relations -#} - {%- set test_outcome = checked_relations | unique | list -%} - - {%- if test_outcome | length > 1 -%} - - {{- return(false) -}} - - {%- elif test_outcome[0] is sameas true -%} - - {{- return(true) -}} - - {%- else -%} - - {{- return(false) -}} - - {%- endif -%} - - {%- endif -%} - -{%- endif -%} - -{%- endmacro -%} \ No newline at end of file diff --git a/macros/internal/multikey.sql b/macros/internal/multikey.sql index 5d181c519..ded071b45 100644 --- a/macros/internal/multikey.sql +++ b/macros/internal/multikey.sql @@ -17,12 +17,12 @@ {% for col in columns if not columns is string %} {% if loop.index == columns|length %} - {{ dbtvault.prefix([col], aliases[0]) }}={{ dbtvault.prefix([col], aliases[1]) }} + {{ dbtvault.prefix([col], aliases[0]) }} = {{ dbtvault.prefix([col], aliases[1]) }} {% else %} - {{ dbtvault.prefix([col], aliases[0]) }}={{ dbtvault.prefix([col], aliases[1]) }} AND + {{ dbtvault.prefix([col], aliases[0]) }} = {{ dbtvault.prefix([col], aliases[1]) }} AND {% endif %} {% else %} - {{ dbtvault.prefix([columns], aliases[0]) }}={{ dbtvault.prefix([columns], aliases[1]) }} + {{ dbtvault.prefix([columns], aliases[0]) }} = {{ dbtvault.prefix([columns], aliases[1]) }} {% endfor %} {% elif type_for == 'where null'%} @@ -41,12 +41,12 @@ {% for col in columns if not columns is string %} {% if loop.index == columns|length %} - {{ dbtvault.prefix([col], aliases[0]) }}<>{{ dbtvault.hash_check(var('hash')) }} - {% else %} - {{ dbtvault.prefix([col], aliases[0]) }}<>{{ dbtvault.hash_check(var('hash')) }} AND - {% endif %} -{% else %} - {{ dbtvault.prefix([columns], aliases[0]) }}<>{{ dbtvault.hash_check(var('hash')) }} + {{ dbtvault.prefix([col], aliases[0]) }} IS NOT NULL + {% else %} + {{ dbtvault.prefix([col], aliases[0]) }} IS NOT NULL AND + {% endif %} +{% else %} + {{ dbtvault.prefix([columns], aliases[0]) }} IS NOT NULL {% endfor %} {% endif %} {% endmacro %} \ No newline at end of file diff --git a/macros/internal/new_union.sql b/macros/internal/new_union.sql deleted file mode 100644 index 8d8fd4144..000000000 --- a/macros/internal/new_union.sql +++ /dev/null @@ -1,36 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro new_union(src_pk, src_nk, src_ldts, src_source, tgt_pk, source) -%} - - SELECT {{ dbtvault.prefix([src_pk, src_nk, src_ldts, src_source], 'src')}}, - LAG({{ src_source }}, 1) - OVER(PARTITION by {{ tgt_pk }} - ORDER BY {{ tgt_pk }}) AS FIRST_SOURCE - FROM ( - - {%- set letters='abcdefghijklmnopqrstuvwxyz' -%} - - {%- set iterations = source|length -%} - - {%- for src in range(iterations) -%} - {%- set letter = letters[loop.index0] %} - {{ dbtvault.single(src_pk, src_nk, src_ldts, src_source, - source[loop.index0], letter) -}} - - {% if not loop.last %} - UNION - {%- endif -%} - {%- endfor %} - ) AS src -{%- endmacro -%} \ No newline at end of file diff --git a/macros/internal/retrieve_tgt_cols.sql b/macros/internal/retrieve_tgt_cols.sql deleted file mode 100644 index fa305b769..000000000 --- a/macros/internal/retrieve_tgt_cols.sql +++ /dev/null @@ -1,101 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro retrieve_tgt_cols() -%} - -{%- set tgt_pk = [ ref(kwargs['tgt_pk']|default(None, true)) ] -%} -{%- set tgt_nk = [ ref(kwargs['tgt_nk']|default(None, true))] -%} -{%- set tgt_fk = kwargs['tgt_fk']|default(None, true) -%} -{%- set tgt_payload = kwargs['tgt_payload']|default(None, true) -%} -{%- set tgt_hashdiff = kwargs['tgt_hashdiff']|default(None, true) -%} -{%- set tgt_eff = kwargs['tgt_eff']|default(None, true) -%} -{%- set tgt_ldts = [ ref(kwargs['tgt_ldts']|default(None, true)) ] -%} -{%- set tgt_source = [ ref(kwargs['tgt_source']|default(None, true)) ] -%} - -{%- set src_pk = kwargs['src_pk']|default(None, true) -%} -{%- set src_nk = kwargs['src_nk']|default(None, true) -%} -{%- set src_fk = kwargs['src_fk']|default(None, true) -%} -{%- set src_payload = kwargs['src_payload']|default(None, true) -%} -{%- set src_hashdiff = kwargs['src_hashdiff']|default(None, true) -%} -{%- set src_eff = kwargs['src_eff']|default(None, true) -%} -{%- set src_ldts = kwargs['src_ldts']|default(None, true) -%} -{%- set src_source = kwargs['src_source']|default(None, true) -%} - -{%- set source = kwargs['source']|default(None, true) -%} - -{%- set tgt_cols_dict = {'tgt_pk': (src_pk, tgt_pk, dbtvault.check_relation(tgt_pk[0])), - 'tgt_nk': (src_nk, tgt_nk, dbtvault.check_relation(tgt_nk[0])), - 'tgt_fk': (src_fk, tgt_fk, dbtvault.check_relation(tgt_fk[0])), - 'tgt_payload': (src_payload, tgt_payload, dbtvault.check_relation(tgt_payload[0])), - 'tgt_hashdiff': (src_hashdiff, tgt_hashdiff, dbtvault.check_relation(tgt_hashdiff[0])), - 'tgt_eff': (src_eff, tgt_eff, dbtvault.check_relation(tgt_eff[0])), - 'tgt_ldts': (src_ldts, tgt_ldts, dbtvault.check_relation(tgt_ldts[0])), - 'tgt_source': (src_source, tgt_source, dbtvault.check_relation(tgt_source[0]))} -%} - -{%- set tgt_cols_output = {'tgt_pk': '', - 'tgt_nk': '', - 'tgt_fk': '', - 'tgt_payload': '', - 'tgt_hashdiff': '', - 'tgt_eff': '', - 'tgt_ldts': '', - 'tgt_source': ''} -%} - -{%- set src_cols_list = dbtvault.get_col_list([src_pk, src_nk, src_fk, - src_payload, src_hashdiff, src_eff, - src_ldts, src_source] | reject("none") | list) -%} - -{%- set columns = adapter.get_columns_in_relation(source[0]) -%} -{%- set column_names = columns | map(attribute='name') | list -%} - -{{ dbtvault.validate_columns(src_cols_list, column_names, source[0]) }} - -{%- for col in tgt_cols_dict -%} - - {%- set src_cols = tgt_cols_dict[col][0] -%} - {%- set tgt_col = tgt_cols_dict[col][1] -%} - {%- set is_relation = tgt_cols_dict[col][2] -%} - {%- set tgt_col_list = [] -%} - - {%- if is_relation -%} - - {#- Add column triples to list -#} - {%- if src_cols is iterable and src_cols is not string -%} - {%- for src_col in src_cols -%} - {%- if src_col in column_names -%} - {%- set col_type = columns | selectattr('name', "equalto", src_col) | map(attribute='data_type') | list | default(" ", true) -%} - - {%- set _ = tgt_col_list.append([src_col, col_type[0], src_col]) -%} - {%- endif -%} - {%- endfor -%} - {%- else -%} - {%- set col_type = columns | selectattr('name', "equalto", src_cols) | map(attribute='data_type' ) | list | default(" ", true) -%} - - {%- set _ = tgt_col_list.append([src_cols, col_type[0], src_cols]) -%} - {%- endif -%} - - {%- if tgt_col_list | length > 1 -%} - {%- set _ = tgt_cols_output.update({col: tgt_col_list}) -%} - {%- else -%} - {%- set _ = tgt_cols_output.update({col: tgt_col_list[0]}) -%} - {%- endif -%} - - {%- else -%} - {%- set _ = tgt_cols_output.update({col: tgt_col}) -%} - {%- endif -%} - -{% endfor %} - -{{ return(tgt_cols_output) }} - -{%- endmacro -%} \ No newline at end of file diff --git a/macros/internal/source_columns.sql b/macros/internal/source_columns.sql deleted file mode 100644 index f4dc52d6c..000000000 --- a/macros/internal/source_columns.sql +++ /dev/null @@ -1,27 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro source_columns(src_pk, src_nk, src_ldts, src_source, - source, is_union) -%} - - {%- if not is_union -%} - - {{- dbtvault.single(src_pk, src_nk, src_ldts, src_source, source[0], 'a') -}} - - {%- else -%} - - {{- dbtvault.new_union(src_pk, src_nk, src_ldts, src_source, src_pk, source) -}} - - {%- endif -%} - -{%- endmacro -%} \ No newline at end of file diff --git a/macros/internal/validate_columns.sql b/macros/internal/validate_columns.sql deleted file mode 100644 index 3d133e71a..000000000 --- a/macros/internal/validate_columns.sql +++ /dev/null @@ -1,24 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro validate_columns(select_columns, source_columns, source_relation) -%} - -{%- if source_columns -%} - {%- for col in select_columns -%} - {%- if col not in source_columns -%} - {{ exceptions.raise_compiler_error("Column '" ~ col ~ "' not present in source '" ~ source_relation.table ~ "', either incorrect source or incorrect source column name.") }} - {%- endif -%} - {%- endfor -%} -{%- endif -%} - -{%- endmacro -%} \ No newline at end of file diff --git a/macros/internal_deprecated/create_source.sql b/macros/internal_deprecated/create_source.sql deleted file mode 100644 index 8014b5681..000000000 --- a/macros/internal_deprecated/create_source.sql +++ /dev/null @@ -1,28 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro create_source(src_pk, src_nk, src_ldts, src_source, - tgt_pk, tgt_nk, tgt_ldts, tgt_source, - source, is_union) -%} - - {%- if not is_union -%} - - {{- dbtvault.single(src_pk, src_nk, src_ldts, src_source, source[0], 'a') -}} - - {%- else -%} - - {{- dbtvault.union(src_pk, src_nk, src_ldts, src_source, tgt_pk, source) -}} - - {%- endif -%} - -{%- endmacro -%} \ No newline at end of file diff --git a/macros/internal_deprecated/create_tgt_cols.sql b/macros/internal_deprecated/create_tgt_cols.sql deleted file mode 100644 index 75358cf0a..000000000 --- a/macros/internal_deprecated/create_tgt_cols.sql +++ /dev/null @@ -1,101 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro create_tgt_cols() -%} - -{%- set tgt_pk = kwargs['tgt_pk']|default(None, true) -%} -{%- set tgt_nk = kwargs['tgt_nk']|default(None, true) -%} -{%- set tgt_fk = kwargs['tgt_fk']|default(None, true) -%} -{%- set tgt_payload = kwargs['tgt_payload']|default(None, true) -%} -{%- set tgt_hashdiff = kwargs['tgt_hashdiff']|default(None, true) -%} -{%- set tgt_eff = kwargs['tgt_eff']|default(None, true) -%} -{%- set tgt_ldts = kwargs['tgt_ldts']|default(None, true) -%} -{%- set tgt_source = kwargs['tgt_source']|default(None, true) -%} - -{%- set src_pk = kwargs['src_pk']|default(None, true) -%} -{%- set src_nk = kwargs['src_nk']|default(None, true) -%} -{%- set src_fk = kwargs['src_fk']|default(None, true) -%} -{%- set src_payload = kwargs['src_payload']|default(None, true) -%} -{%- set src_hashdiff = kwargs['src_hashdiff']|default(None, true) -%} -{%- set src_eff = kwargs['src_eff']|default(None, true) -%} -{%- set src_ldts = kwargs['src_ldts']|default(None, true) -%} -{%- set src_source = kwargs['src_source']|default(None, true) -%} - -{%- set source = kwargs['source']|default(None, true) -%} - -{%- set tgt_cols_dict = {'tgt_pk': (src_pk, tgt_pk, dbtvault.check_relation(tgt_pk[0])), - 'tgt_nk': (src_nk, tgt_nk, dbtvault.check_relation(tgt_nk[0])), - 'tgt_fk': (src_fk, tgt_fk, dbtvault.check_relation(tgt_fk[0])), - 'tgt_payload': (src_payload, tgt_payload, dbtvault.check_relation(tgt_payload[0])), - 'tgt_hashdiff': (src_hashdiff, tgt_hashdiff, dbtvault.check_relation(tgt_hashdiff[0])), - 'tgt_eff': (src_eff, tgt_eff, dbtvault.check_relation(tgt_eff[0])), - 'tgt_ldts': (src_ldts, tgt_ldts, dbtvault.check_relation(tgt_ldts[0])), - 'tgt_source': (src_source, tgt_source, dbtvault.check_relation(tgt_source[0]))} -%} - -{%- set tgt_cols_output = {'tgt_pk': '', - 'tgt_nk': '', - 'tgt_fk': '', - 'tgt_payload': '', - 'tgt_hashdiff': '', - 'tgt_eff': '', - 'tgt_ldts': '', - 'tgt_source': ''} -%} - -{%- set src_cols_list = dbtvault.get_col_list([src_pk, src_nk, src_fk, - src_payload, src_hashdiff, src_eff, - src_ldts, src_source] | reject("none") | list) -%} - -{%- set columns = adapter.get_columns_in_relation(source[0]) -%} -{%- set column_names = columns | map(attribute='name') | list -%} - -{{ dbtvault.validate_columns(src_cols_list, column_names, source[0]) }} - -{%- for col in tgt_cols_dict -%} - - {%- set src_cols = tgt_cols_dict[col][0] -%} - {%- set tgt_col = tgt_cols_dict[col][1] -%} - {%- set is_relation = tgt_cols_dict[col][2] -%} - {%- set tgt_col_list = [] -%} - - {%- if is_relation -%} - - {#- Add column triples to list -#} - {%- if src_cols is iterable and src_cols is not string -%} - {%- for src_col in src_cols -%} - {%- if src_col in column_names -%} - {%- set col_type = columns | selectattr('name', "equalto", src_col) | map(attribute='data_type') | list | default(" ", true) -%} - - {%- set _ = tgt_col_list.append([src_col, col_type[0], src_col]) -%} - {%- endif -%} - {%- endfor -%} - {%- else -%} - {%- set col_type = columns | selectattr('name', "equalto", src_cols) | map(attribute='data_type' ) | list | default(" ", true) -%} - - {%- set _ = tgt_col_list.append([src_cols, col_type[0], src_cols]) -%} - {%- endif -%} - - {%- if tgt_col_list | length > 1 -%} - {%- set _ = tgt_cols_output.update({col: tgt_col_list}) -%} - {%- else -%} - {%- set _ = tgt_cols_output.update({col: tgt_col_list[0]}) -%} - {%- endif -%} - - {%- else -%} - {%- set _ = tgt_cols_output.update({col: tgt_col}) -%} - {%- endif -%} - -{% endfor %} - -{{ return(tgt_cols_output) }} - -{%- endmacro -%} \ No newline at end of file diff --git a/macros/internal_deprecated/union.sql b/macros/internal_deprecated/union.sql deleted file mode 100644 index 45f1290b4..000000000 --- a/macros/internal_deprecated/union.sql +++ /dev/null @@ -1,35 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro union(src_pk, src_nk, src_ldts, src_source, tgt_pk, source) -%} - - SELECT {{ dbtvault.prefix([src_pk, src_nk, src_ldts, src_source], 'src')}}, - LAG({{ src_source }}, 1) - OVER(PARTITION by {{ tgt_pk | last }} - ORDER BY {{ tgt_pk | last }}) AS FIRST_SOURCE - FROM ( - - {%- set letters='abcdefghijklmnopqrstuvwxyz' -%} - - {%- set iterations = source|length -%} - - {%- for src in range(iterations) -%} - {%- set letter = letters[loop.index0] %} - {{ dbtvault.single(src_pk, src_nk, src_ldts, src_source, - source[loop.index0], letter) -}} - {% if not loop.last %} - UNION - {%- endif -%} - {%- endfor %} - ) AS src -{%- endmacro -%} \ No newline at end of file diff --git a/macros/staging/add_columns.sql b/macros/staging/add_columns.sql deleted file mode 100644 index 14593889d..000000000 --- a/macros/staging/add_columns.sql +++ /dev/null @@ -1,49 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro add_columns(source, pairs=[]) -%} - -{%- set exclude_columns = [] -%} -{%- set include_columns = [] -%} - -{%- if source is defined and source is not none -%} -{%- set cols = adapter.get_columns_in_relation(source) -%} -{%- endif %} - -{#- Add aliases of provided pairs to excludes and full SQL to includes -#} -{%- for pair in pairs -%} - {%- if pair[0] | first == "!" -%} - {%- set _ = include_columns.append("'" ~ pair[0][1:] ~ "' AS " ~ pair[1]) -%} - {%- set _ = exclude_columns.append(pair[1]) -%} - {%- else -%} - {%- set _ = include_columns.append(pair[0] ~ " AS " ~ pair[1]) -%} - {%- set _ = exclude_columns.append(pair[1]) -%} - {%- endif %} -{%- endfor -%} - -{%- if source is defined and source is not none -%} -{#- Add all columns from source table -#} -{%- for col in cols -%} - {%- if col.column not in exclude_columns -%} - {%- set _ = include_columns.append(col.column) -%} - {%- endif -%} -{%- endfor -%} -{%- endif %} - -{#- Print out all columns in includes -#} -{%- for col in include_columns %} - {{ col }}{%if not loop.last %}, -{%- endif -%} - -{%- endfor -%} -{%- endmacro -%} \ No newline at end of file diff --git a/macros/staging/derive_columns.sql b/macros/staging/derive_columns.sql new file mode 100644 index 000000000..9edc2f315 --- /dev/null +++ b/macros/staging/derive_columns.sql @@ -0,0 +1,79 @@ +{#- Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +-#} + +{%- macro derive_columns(source_relation=none, columns=none) -%} + +{%- set exclude_columns = [] -%} +{%- set include_columns = [] -%} + +{%- if source_relation is defined and source_relation is not none -%} + {%- set source_model_cols = adapter.get_columns_in_relation(source_relation) -%} +{%- endif %} + +{%- if columns is mapping and columns is not none -%} + + {#- Add aliases of provided columns to excludes and full SQL to includes -#} + {%- for col in columns -%} + + {% set column_str = dbtvault.as_constant(columns[col]) %} + + {%- set _ = include_columns.append(column_str ~ " AS " ~ col) -%} + {%- set _ = exclude_columns.append(col) -%} + + {%- endfor -%} + + {#- Add all columns from source_model relation -#} + {%- if source_relation is defined and source_relation is not none -%} + + {%- for source_col in source_model_cols -%} + {%- if source_col.column not in exclude_columns -%} + {%- set _ = include_columns.append(source_col.column) -%} + {%- endif -%} + {%- endfor -%} + + {%- endif %} + + {#- Print out all columns in includes -#} + {%- for col in include_columns -%} + {{ col }} + {%- if not loop.last -%}, +{% endif -%} + {%- endfor -%} + +{%- elif columns is none and source_relation is not none -%} + + {#- Add all columns from source_model relation -#} + {%- for source_col in source_model_cols -%} + {%- if source_col.column not in exclude_columns -%} + {%- set _ = include_columns.append(source_col.column) -%} + {%- endif -%} + {%- endfor -%} + + {#- Print out all columns in includes -#} + {%- for col in include_columns -%} + {{ col }} + {{- ',\n' if not loop.last -}} + + {%- endfor -%} + +{%- else -%} + +{%- if execute -%} +{{ exceptions.raise_compiler_error("Invalid column configuration: +expected format: {source_relation: Relation, columns: 'column_mapping'} +got: {'source_relation': " ~ source_relation ~ ", 'columns': " ~ columns ~ "}") }} +{%- endif %} + +{%- endif %} + +{%- endmacro -%} \ No newline at end of file diff --git a/macros/staging/hash_columns.sql b/macros/staging/hash_columns.sql new file mode 100644 index 000000000..46fd5a45f --- /dev/null +++ b/macros/staging/hash_columns.sql @@ -0,0 +1,43 @@ +{#- Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +-#} + +{%- macro hash_columns(columns=none) -%} + +{%- if columns is mapping -%} + + {%- for col in columns -%} + + {% if columns[col] is mapping and columns[col].hashdiff -%} + + {{- dbtvault.hash(columns[col]['columns'], col, columns[col]['hashdiff']) -}} + + {%- elif columns[col] is not mapping -%} + + {{- dbtvault.hash(columns[col], col, hashdiff=false) -}} + + {%- elif columns[col] is mapping and not columns[col].hashdiff -%} + + {%- if execute -%} + {%- do exceptions.warn("[" ~ this ~ "] Warning: You provided a list of columns under a 'columns' key, but did not provide the 'hashdiff' flag. Use list syntax for PKs.") -%} + {% endif %} + + {{- dbtvault.hash(columns[col]['columns'], col) -}} + + {%- endif -%} + + {%- if not loop.last -%}, +{% endif %} + {%- endfor -%} + +{%- endif -%} +{%- endmacro -%} diff --git a/macros/staging/multi_hash.sql b/macros/staging/multi_hash.sql deleted file mode 100644 index 06c8ce17b..000000000 --- a/macros/staging/multi_hash.sql +++ /dev/null @@ -1,30 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro multi_hash(triples) -%} --- Generated by dbtvault. -SELECT -{% for triple in triples -%} - {%- if triple | length == 2 -%} - - {{ dbtvault.hash(triple[0], triple[1]) }} - - {%- elif triple | length == 3 and triple | last == true -%} - - {{ dbtvault.hash(triple[0], triple[1], triple[2]) }} - - {%- endif -%} - - {% if not loop.last -%}, {% endif %} -{%- endfor -%} -{%- endmacro -%} diff --git a/macros/staging/stage.sql b/macros/staging/stage.sql new file mode 100644 index 000000000..4e049bc0b --- /dev/null +++ b/macros/staging/stage.sql @@ -0,0 +1,80 @@ + {#- Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +-#} +{%- macro stage(include_source_columns=none, source_model=none, hashed_columns=none, derived_columns=none) -%} + + {% if include_source_columns is none %} + {%- set include_source_columns = true -%} + {% endif %} + + {{- adapter_macro('dbtvault.stage', include_source_columns=include_source_columns, source_model=source_model, hashed_columns=hashed_columns, derived_columns=derived_columns) -}} +{%- endmacro -%} + +{%- macro default__stage(include_source_columns, source_model, hashed_columns, derived_columns) -%} +-- Generated by dbtvault. + +{% if (source_model is none) and execute %} + + {%- set error_message -%} + "Staging error: Missing source_model configuration. A source model name must be provided. + e.g. + [REF STYLE] + source_model: model_name + OR + [SOURCES STYLE] + source_model: + source_name: source_table_name" + {%- endset -%} + + {{- exceptions.raise_compiler_error(error_message) -}} +{%- endif -%} + +SELECT + +{# Create relation object from provided source_model -#} +{% if source_model is mapping and source_model is not none -%} + + {%- set source_name = source_model | first -%} + {%- set source_table_name = source_model[source_name] -%} + + {%- set source_relation = source(source_name, source_table_name) -%} + +{%- elif source_model is not mapping and source_model is not none -%} + + {%- set source_relation = ref(source_model) -%} +{%- endif -%} + +{#- Hash columns, if provided -#} +{% if hashed_columns is defined and hashed_columns is not none -%} + + {{ dbtvault.hash_columns(columns=hashed_columns) -}} + {{ "," if derived_columns is defined and source_relation is defined and include_source_columns }} + +{% endif -%} + +{#- Derive additional columns, if provided -#} +{%- if derived_columns is defined and derived_columns is not none -%} + + {%- if include_source_columns -%} + {{ dbtvault.derive_columns(source_relation=source_relation, columns=derived_columns) }} + {%- else -%} + {{ dbtvault.derive_columns(columns=derived_columns) }} + {%- endif -%} +{#- If source relation is defined but derived_columns is not, add columns from source model. -#} +{%- elif source_relation is defined and include_source_columns is true -%} + + {{ dbtvault.derive_columns(source_relation=source_relation) }} +{%- endif %} + +FROM {{ source_relation }} + +{%- endmacro -%} \ No newline at end of file diff --git a/macros/supporting/cast.sql b/macros/supporting/cast.sql index 9e3e02abd..4fbbba041 100644 --- a/macros/supporting/cast.sql +++ b/macros/supporting/cast.sql @@ -19,7 +19,7 @@ {#- If only single string provided -#} {%- if columns is string -%} - {{columns}} + {{- columns -}} {%- else -%} @@ -27,22 +27,22 @@ {#- Output String if just a string -#} {%- if column is string -%} - {% if prefix %} - {{ dbtvault.prefix([column], prefix) }} - {%- else %} - {{ column }} + {%- if prefix -%} + {{- dbtvault.prefix([column], prefix) -}} + {%- else -%} + {{- column -}} {%- endif -%} {#- Recurse if a list of lists (i.e. multi-column key) -#} {%- elif column|first is iterable and column|first is not string -%} - {{ dbtvault.cast(column, prefix) }} + {{- dbtvault.cast(column, prefix) -}} {#- Otherwise it is a standard list -#} {%- else -%} {#- Make sure it is a triple -#} - {%- if column|length == 3 %} - {% if prefix -%} + {%- if column|length == 3 -%} + {%- if prefix -%} CAST({{ dbtvault.prefix([column[0]], prefix) }} AS {{ column[1] }}) AS {{ column[2] }} {%- else -%} CAST({{ column[0] }} AS {{ column[1] }}) AS {{ column[2] }} @@ -52,7 +52,7 @@ {%- endif -%} {#- Add trailing comma if not last -#} - {%- if not loop.last -%} , {%- endif -%} + {{ ',\n' if not loop.last }} {%- endfor -%} diff --git a/macros/supporting/hash.sql b/macros/supporting/hash.sql index a60239df5..290070046 100644 --- a/macros/supporting/hash.sql +++ b/macros/supporting/hash.sql @@ -1,17 +1,17 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); +{# Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at - http://www.apache.org/licenses/LICENSE-2.0 + http://www.apache.org/licenses/LICENSE2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. --#} +#} -{%- macro hash(columns, alias, sort=false) -%} +{%- macro hash(columns=none, alias=none, hashdiff=false) -%} {%- set hash = var('hash', 'MD5') -%} @@ -27,24 +27,34 @@ {%- set hash_size = 16 -%} {%- endif -%} -{#- Alpha sort columns before hashing -#} -{%- if sort and columns is iterable and columns is not string -%} -{%- set columns = columns|sort -%} +{#- Alpha sort columns before hashing if a hashdiff -#} +{%- if hashdiff and columns is iterable and columns is not string -%} + {%- set columns = columns|sort -%} {%- endif -%} -{%- if columns is string %} - CAST({{- hash_alg -}}(IFNULL((UPPER(TRIM(CAST({{columns}} AS VARCHAR)))), '^^')) AS BINARY({{- hash_size -}})) AS {{alias}} +{#- If single column to hash -#} +{%- if columns is string -%} + {%- set column_str = dbtvault.as_constant(columns) -%} + CAST(({{ hash_alg }}(NULLIF(UPPER(TRIM(CAST({{ column_str }} AS VARCHAR))), ''))) AS BINARY({{ hash_size }})) AS {{ alias }} +{#- Else a list of columns to hash -#} +{%- else -%} + +CAST({{ hash_alg }}(CONCAT( + +{%- for column in columns %} + +{%- set column_str = dbtvault.as_constant(column) -%} + +{%- if not loop.last %} + IFNULL(NULLIF(UPPER(TRIM(CAST({{ column_str }} AS VARCHAR))), ''), '^^'), '||', {%- else %} + IFNULL(NULLIF(UPPER(TRIM(CAST({{ column_str }} AS VARCHAR))), ''), '^^') )) +AS BINARY({{ hash_size }})) AS {{ alias }} +{%- endif -%} - CAST({{- hash_alg -}}(CONCAT( -{%- for column in columns[:-1] %} - IFNULL(UPPER(TRIM(CAST({{- column }} AS VARCHAR))), '^^'), '||', +{%- endfor -%} +{%- endif -%} -{%- if loop.last %} - IFNULL(UPPER(TRIM(CAST({{columns[-1]}} AS VARCHAR))), '^^') )) AS BINARY({{- hash_size -}})) AS {{alias}} -{%- endif -%} -{%- endfor -%} -{%- endif -%} {%- endmacro -%} diff --git a/macros/supporting/prefix.sql b/macros/supporting/prefix.sql index d8e5d3ee2..fe081258e 100644 --- a/macros/supporting/prefix.sql +++ b/macros/supporting/prefix.sql @@ -11,18 +11,56 @@ limitations under the License. -#} -{%- macro prefix(columns, prefix_str) -%} +{%- macro prefix(columns=none, prefix_str=none, alias_target='source') -%} -{%- for column in columns -%} + {%- if columns and prefix_str -%} - {% if column is iterable and column is not string %} - {{- dbtvault.prefix(column, prefix_str) -}} - {%- else -%} - {{- prefix_str}}.{{column.strip() -}} - {%- endif -%} + {%- for col in columns -%} + + {%- if col is mapping -%} + + {%- if alias_target == 'source' -%} + + {{- dbtvault.prefix([col['source_column']], prefix_str) -}} + + {%- elif alias_target == 'target' -%} + + {{- dbtvault.prefix([col['alias']], prefix_str) -}} + + {%- else -%} + + {{- dbtvault.prefix([col['source_column']], prefix_str) -}} + + {%- endif -%} + + {%- if not loop.last -%} , {% endif %} - {%- if not loop.last -%} , {% endif %} + {%- else -%} -{%- endfor -%} + {%- if col is iterable and col is not string -%} + + {{- dbtvault.prefix(col, prefix_str) -}} + + {%- elif col is not none -%} + {{- prefix_str}}.{{col.strip() -}} + {% else %} + + {%- if execute -%} + {{- exceptions.raise_compiler_error("Unexpected or missing configuration for '" ~ this ~ "' Unable to prefix columns.") -}} + {%- endif -%} + {%- endif -%} + + {{- ', ' if not loop.last -}} + + {%- endif -%} + + {%- endfor -%} + + {%- else -%} + + {%- if execute -%} + {{- exceptions.raise_compiler_error("Invalid parameters provided to prefix macro. Expected: (columns [list/string], prefix_str [string]) got: (" ~ columns ~ ", " ~ prefix_str ~ ")") -}} + {%- endif -%} + {%- endif -%} {%- endmacro -%} \ No newline at end of file diff --git a/macros/tables/eff_sat.sql b/macros/tables/eff_sat.sql deleted file mode 100644 index eb4ab9d0f..000000000 --- a/macros/tables/eff_sat.sql +++ /dev/null @@ -1,114 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro eff_sat(src_pk, src_dfk, src_sfk, src_ldts, src_eff_from, src_start_date, src_end_date, src_source, link, source)-%} - -{%- set source_cols = dbtvault.get_src_col_list([src_pk, src_ldts, src_eff_from, src_start_date, src_end_date, src_source])-%} -{%- set max_date = "'" ~ '9999-12-31' ~ "'" -%} --- Generated by dbtvault. -{% if is_incremental() %} -WITH -{#- Reduce data set to size of stage table. #} -c AS (SELECT DISTINCT - {{ dbtvault.prefix(source_cols, 'a') }} - FROM {{ this }} AS a - INNER JOIN {{ ref(source) }} AS b ON {{ dbtvault.prefix([src_pk], 'a') }}={{ dbtvault.prefix([src_pk], 'b') }} - ) -{# Find latest satellite for each pk in set c. -#} -, d as (SELECT - {{ dbtvault.prefix(source_cols, 'c') }}, - CASE WHEN RANK() - OVER (PARTITION BY {{ dbtvault.prefix([src_pk], 'c') }} - ORDER BY {{ dbtvault.prefix([src_end_date], 'c') }} ASC) = 1 - THEN 'Y' ELSE 'N' END AS CURR_FLG - FROM c) -, p AS ( - SELECT q.* FROM {{ ref(link) }} AS q - INNER JOIN {{ ref(source) }} AS r ON - {{ dbtvault.multikey(src_dfk, ['q', 'r'], 'join') }} -) -, x AS ( - SELECT p.* - {% for dfk in src_dfk if not src_dfk is string %} - , {{ dbtvault.prefix([dfk], 's') }} AS DFK_{{ loop.index }} - {% else %} - , {{ dbtvault.prefix([src_dfk], 's') }} AS DFK_1 - {% endfor %} - FROM p - LEFT JOIN {{ ref(source) }} AS s ON - {{ dbtvault.multikey(src_dfk, ['p', 's'], 'join') }} - AND - {{ dbtvault.multikey(src_sfk, ['p', 's'], 'join') }} - WHERE ( - {{ dbtvault.multikey(src_dfk, ['s'], 'where null') }} - AND - {{ dbtvault.multikey(src_sfk, ['s'], 'where null') }} - ) -) -, y AS ( - SELECT - {{ dbtvault.prefix([src_pk, src_ldts, src_source, src_eff_from, src_start_date, src_end_date], 't') }} - {% for dfk in src_dfk if not src_dfk is string %} - , {{ dbtvault.prefix(['DFK_'~loop.index ], 'x') }} - {% else %} - , {{ dbtvault.prefix(['DFK_1'], 'x') }} - {% endfor %} - , {{ dbtvault.prefix([src_dfk], 'x')}}, - CASE WHEN RANK() - OVER (PARTITION BY {{ dbtvault.prefix([src_pk], 't') }} - ORDER BY {{ dbtvault.prefix([src_end_date], 't') }} ASC) = 1 - THEN 'Y' ELSE 'N' END AS CURR_FLG - FROM x - INNER JOIN {{ this }} AS t ON {{ dbtvault.prefix([src_pk], 'x') }}={{ dbtvault.prefix([src_pk], 't') }} - ) -{% endif %} -SELECT DISTINCT - {{ dbtvault.prefix([src_pk, src_ldts, src_source, src_eff_from], 'e') }}, - {{ dbtvault.prefix([src_eff_from], 'e') }} AS {{ src_start_date }}, - {{ dbtvault.prefix([src_end_date], 'e') }} -FROM {{ ref(source) }} AS e -{% if is_incremental() -%} -LEFT JOIN ( - SELECT {{ dbtvault.prefix(source_cols, 'd')}} - FROM d - WHERE d.CURR_FLG = 'Y' AND {{ dbtvault.prefix([src_end_date], 'd') }}=TO_DATE({{ max_date }}) - ) AS eff -ON {{ dbtvault.prefix([src_pk], 'eff') }}={{ dbtvault.prefix([src_pk], 'e') }} -WHERE ({{ dbtvault.prefix([src_pk], 'eff') }} IS NULL -AND -{{ dbtvault.multikey(src_sfk, ['e'], 'where not null') }} -AND -{{ dbtvault.multikey(src_dfk, ['e'], 'where not null') }} -) -UNION -SELECT - {{ dbtvault.prefix([src_pk], 'y') }}, - {{ dbtvault.prefix([src_ldts], 'z') }}, - {{ dbtvault.prefix([src_source, src_eff_from, src_start_date], 'y') }}, - CASE WHEN - {% for dfk in src_dfk if not src_dfk is string %} - {% if loop.index == src_dfk|length %} - y.DFK_{{loop.index|string}} IS NULL - {% else %} - y.DFK_{{loop.index|string}} IS NULL AND - {% endif %} - {% else %} - y.DFK_1 IS NULL - {% endfor %} - THEN {{ dbtvault.prefix([src_eff_from], 'z') }} ELSE {{ max_date }} END AS {{ src_end_date }} -FROM y -LEFT JOIN {{ ref(source) }} AS z ON -{{ dbtvault.multikey(src_dfk, ['y', 'z'], 'join') }} -WHERE (y.CURR_FLG='Y' AND {{ dbtvault.prefix([src_end_date], 'y') }}={{ max_date }}) -{%- endif -%} -{% endmacro %} \ No newline at end of file diff --git a/macros/tables/hub.sql b/macros/tables/hub.sql index 634e10bcf..33b78ded4 100644 --- a/macros/tables/hub.sql +++ b/macros/tables/hub.sql @@ -11,30 +11,75 @@ limitations under the License. -#} -{%- macro hub(src_pk, src_nk, src_ldts, src_source, - source) -%} +{%- macro hub(src_pk, src_nk, src_ldts, src_source, source_model) -%} -{%- set source_data = dbtvault.is_multi_source(source, src_pk, src_nk, src_ldts, src_source) -%} -{%- set source_col = source_data[0] -%} -{%- set is_union = source_data[1] -%} +{%- set source_cols = dbtvault.expand_column_list([src_pk, src_nk, src_ldts, src_source]) -%} -- Generated by dbtvault. -SELECT DISTINCT {{ dbtvault.prefix([src_pk, src_nk, src_ldts, src_source], 'stg') }} -FROM ( - {{ source_col }} -) AS stg -{# If incremental union or single #} -{%- if is_incremental() -%} -LEFT JOIN {{ this }} AS tgt -ON {{ dbtvault.prefix([src_pk], 'stg') }} = {{ dbtvault.prefix([src_pk], 'tgt') }} -WHERE {{ dbtvault.prefix([src_pk], 'tgt') }} IS NULL -{# If an incremental and union load -#} -{% if is_union -%} -AND stg.FIRST_SOURCE IS NULL -{%- endif -%} -{%- endif -%} -{# If a union base-load #} -{%- if is_union and not is_incremental() -%} -WHERE stg.FIRST_SOURCE IS NULL +{{ 'WITH ' -}} + +{%- if source_model is iterable and source_model is not string -%} + +{%- for src in source_model -%} + +STG_{{ loop.index|string }} AS ( + SELECT DISTINCT + {{ dbtvault.prefix(source_cols, 'a') }} + FROM ( + SELECT {{ src_pk }}, {{ src_nk }}, {{ src_ldts }}, {{ src_source }}, + ROW_NUMBER() OVER( + PARTITION BY {{ src_pk }} + ORDER BY {{ src_ldts }} ASC + ) AS RN + FROM {{ ref(src) }} + ) AS a + WHERE RN = 1 +), +{% endfor -%} +STG AS ( + SELECT DISTINCT + {{ dbtvault.prefix(source_cols, 'b') }} + FROM ( + SELECT *, + ROW_NUMBER() OVER( + PARTITION BY {{ src_pk }} + ORDER BY {{ src_ldts }}, {{ src_source }} ASC + ) AS RN + FROM ( + {%- for src in source_model %} + SELECT * {{ 'FROM ' -}} STG_{{ loop.index|string }} + {%- if not loop.last %} + UNION ALL + {%- endif %} + {%- endfor %} + ) + WHERE {{ src_pk }} IS NOT NULL + ) AS b + WHERE RN = 1 +) +{%- else -%} + +STG AS ( + SELECT DISTINCT + {{ dbtvault.prefix(source_cols, 'a') }} + FROM ( + SELECT b.*, + ROW_NUMBER() OVER( + PARTITION BY {{ dbtvault.prefix([src_pk], 'b') }} + ORDER BY {{ dbtvault.prefix([src_ldts], 'b') }}, {{ dbtvault.prefix([src_source], 'b') }} ASC + ) AS RN + FROM {{ ref(source_model) }} AS b + WHERE {{ dbtvault.prefix([src_pk], 'b') }} IS NOT NULL + ) AS a + WHERE RN = 1 +) +{%- endif %} + +SELECT c.* FROM STG AS c +{%- if is_incremental() %} +LEFT JOIN {{ this }} AS d +ON {{ dbtvault.prefix([src_pk], 'c') }} = {{ dbtvault.prefix([src_pk], 'd') }} +WHERE {{ dbtvault.prefix([src_pk], 'd') }} IS NULL {%- endif -%} + {%- endmacro -%} \ No newline at end of file diff --git a/macros/tables/link.sql b/macros/tables/link.sql index 357129aba..9270a9999 100644 --- a/macros/tables/link.sql +++ b/macros/tables/link.sql @@ -11,44 +11,94 @@ limitations under the License. -#} -{%- macro link(src_pk, src_fk, src_ldts, src_source, - source) -%} +{%- macro link(src_pk, src_fk, src_ldts, src_source, source_model) -%} -{%- set source_data = dbtvault.is_multi_source(source, src_pk, src_fk, src_ldts, src_source) -%} -{%- set source_col = source_data[0] -%} -{%- set is_union = source_data[1] -%} +{%- set source_cols = dbtvault.expand_column_list([src_pk, src_fk, src_ldts, src_source]) -%} +{%- set fk_cols = dbtvault.expand_column_list([src_fk]) -%} -- Generated by dbtvault. -SELECT DISTINCT {{ dbtvault.prefix([src_pk, src_fk, src_ldts, src_source], 'stg') }} -FROM ( - {{ source_col }} -) AS stg -{# If incremental union or single #} -{%- if is_incremental() -%} -LEFT JOIN {{ this }} AS tgt -ON {{ dbtvault.prefix([src_pk], 'stg') }} = {{ dbtvault.prefix([src_pk], 'tgt') }} -WHERE {{ dbtvault.prefix([src_pk], 'tgt') }} IS NULL -{% if is_union -%} -AND stg.FIRST_SOURCE IS NULL -{%- endif -%} -{%- for fk in src_fk %} -AND {{ dbtvault.prefix([fk], 'stg') }}<>{{ dbtvault.hash_check(var('hash')) }} -{% endfor %} -{%- elif not is_incremental() -%} -{% if is_union %} -WHERE stg.FIRST_SOURCE IS NULL -{%- for fk in src_fk %} -AND {{ dbtvault.prefix([fk], 'stg') }}<>{{ dbtvault.hash_check(var('hash')) }} -{% endfor %} -{% else %} -WHERE -{%- for fk in src_fk %} -{% if loop.index == src_fk|length %} -{{ dbtvault.prefix([fk], 'stg') }}<>{{ dbtvault.hash_check(var('hash')) }} -{% else %} -{{ dbtvault.prefix([fk], 'stg') }}<>{{ dbtvault.hash_check(var('hash')) }} AND -{% endif %} -{% endfor %} -{% endif %} +{{ 'WITH ' -}} + +{%- if source_model is iterable and source_model is not string -%} + +{%- for src in source_model -%} + +STG_{{ loop.index|string }} AS ( + SELECT DISTINCT + {{ dbtvault.prefix(source_cols, 'a') }} + FROM ( + SELECT {{ src_pk }} + {%- for fk in fk_cols -%} + , {{ fk }} + {%- endfor -%} + , {{ src_ldts }}, {{ src_source }}, + ROW_NUMBER() OVER( + PARTITION BY {{ src_pk }} + ORDER BY {{ src_ldts }} ASC + ) AS RN + FROM {{ ref(src) }} + ) AS a + WHERE RN = 1 +), +{% endfor -%} + +STG AS ( + SELECT DISTINCT + {{ dbtvault.prefix(source_cols, 'b') }} + FROM ( + SELECT *, + ROW_NUMBER() OVER( + PARTITION BY {{ src_pk }} + ORDER BY {{ src_ldts }}, {{ src_source }} ASC + ) AS RN + FROM ( + {%- for src in source_model %} + SELECT * FROM STG_{{ loop.index|string }} + {%- if not loop.last %} + UNION ALL + {%- endif %} + {%- endfor %} + ) + {{ 'WHERE' -}} + {%- for fk in fk_cols -%} + {%- if not loop.last %} + {{ fk }} IS NOT NULL AND + {%- else %} + {{ fk }} IS NOT NULL + {%- endif -%} + {%- endfor %} + ) AS b + WHERE RN = 1 +) +{%- else -%} +STG AS ( + SELECT DISTINCT + {{ dbtvault.prefix(source_cols, 'a') }} + FROM ( + SELECT b.*, + ROW_NUMBER() OVER( + PARTITION BY {{ dbtvault.prefix([src_pk], 'b') }} + ORDER BY b.{{ src_ldts }}, b.{{ src_source }} ASC + ) AS RN + FROM {{ ref(source_model) }} AS b + {{ 'WHERE' -}} + {%- for fk in fk_cols -%} + {%- if not loop.last %} + b.{{ fk }} IS NOT NULL AND + {%- else %} + b.{{ fk }} IS NOT NULL + {%- endif -%} + {%- endfor %} + ) AS a + WHERE RN = 1 +) +{%- endif %} + +SELECT c.* FROM STG AS c +{%- if is_incremental() %} +LEFT JOIN {{ this }} AS d +ON {{ dbtvault.prefix([src_pk], 'c') }} = {{ dbtvault.prefix([src_pk], 'd') }} +WHERE {{ dbtvault.prefix([src_pk], 'd') }} IS NULL {%- endif -%} + {%- endmacro -%} \ No newline at end of file diff --git a/macros/tables/sat.sql b/macros/tables/sat.sql index fc6201fa4..3e97103e8 100644 --- a/macros/tables/sat.sql +++ b/macros/tables/sat.sql @@ -11,34 +11,35 @@ limitations under the License. -#} -{%- macro sat(src_pk, src_hashdiff, src_payload, - src_eff, src_ldts, src_source, - source) -%} +{%- macro sat(src_pk, src_hashdiff, src_payload, src_eff, src_ldts, src_source, source_model) -%} -{%- set source_cols = dbtvault.get_src_col_list([src_pk, src_hashdiff, src_payload, src_eff, src_ldts, src_source]) -%} +{%- set source_cols = dbtvault.expand_column_list([src_pk, src_hashdiff, src_payload, src_eff, src_ldts, src_source]) -%} -- Generated by dbtvault. -SELECT DISTINCT {{ dbtvault.prefix(source_cols, 'e') }} -FROM {{ ref(source) }} AS e -{% if is_incremental() -%} +{% if not is_incremental() -%} +SELECT DISTINCT {{ dbtvault.alias_all(source_cols, 'e') }} +FROM {{ ref(source_model) }} AS e +{% else -%} +SELECT DISTINCT {{ dbtvault.alias_all(source_cols, 'e') }} +FROM {{ ref(source_model) }} AS e LEFT JOIN ( - SELECT {{ dbtvault.prefix(source_cols, 'd') }} + SELECT {{ dbtvault.prefix(source_cols, 'd', alias_target='target') }} FROM ( - SELECT {{ dbtvault.prefix(source_cols, 'c') }}, + SELECT {{ dbtvault.prefix(source_cols, 'c', alias_target='target') }}, CASE WHEN RANK() OVER (PARTITION BY {{ dbtvault.prefix([src_pk], 'c') }} ORDER BY {{ dbtvault.prefix([src_ldts], 'c') }} DESC) = 1 THEN 'Y' ELSE 'N' END CURR_FLG FROM ( - SELECT {{ dbtvault.prefix(source_cols, 'a') }} + SELECT {{ dbtvault.prefix(source_cols, 'a', alias_target='target') }} FROM {{ this }} as a - JOIN {{ ref(source) }} as b + JOIN {{ ref(source_model) }} as b ON {{ dbtvault.prefix([src_pk], 'a') }} = {{ dbtvault.prefix([src_pk], 'b') }} ) as c ) AS d WHERE d.CURR_FLG = 'Y') AS src -ON {{ dbtvault.prefix([src_hashdiff], 'src') }} = {{ dbtvault.prefix([src_hashdiff], 'e') }} -WHERE {{ dbtvault.prefix([src_hashdiff], 'src') }} IS NULL +ON {{ dbtvault.prefix([src_hashdiff], 'src', alias_target='target') }} = {{ dbtvault.prefix([src_hashdiff], 'e') }} +WHERE {{ dbtvault.prefix([src_hashdiff], 'src', alias_target='target') }} IS NULL {%- endif -%} {% endmacro %} diff --git a/macros/tables/t_link.sql b/macros/tables/t_link.sql index 8833a414c..5b9fac9b9 100644 --- a/macros/tables/t_link.sql +++ b/macros/tables/t_link.sql @@ -11,15 +11,15 @@ limitations under the License. -#} -{%- macro t_link(src_pk, src_fk, src_payload, src_eff, src_ldts, src_source, source) -%} +{%- macro t_link(src_pk, src_fk, src_payload, src_eff, src_ldts, src_source, source_model) -%} -{%- set source_cols = dbtvault.get_src_col_list([src_pk, src_fk, src_payload, src_eff, src_ldts, src_source])-%} +{%- set source_cols = dbtvault.expand_column_list([src_pk, src_fk, src_payload, src_eff, src_ldts, src_source])-%} -- Generated by dbtvault. SELECT DISTINCT {{ dbtvault.prefix(source_cols, 'stg') }} FROM ( SELECT {{ dbtvault.prefix(source_cols, 'stg') }} - FROM {{ ref(source) }} AS stg + FROM {{ ref(source_model) }} AS stg ) AS stg {% if is_incremental() -%} LEFT JOIN {{ this }} AS tgt diff --git a/macros/tables_deprecated/hub_template.sql b/macros/tables_deprecated/hub_template.sql deleted file mode 100644 index e7a9b7060..000000000 --- a/macros/tables_deprecated/hub_template.sql +++ /dev/null @@ -1,49 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro hub_template(src_pk, src_nk, src_ldts, src_source, - tgt_pk, tgt_nk, tgt_ldts, tgt_source, - source) -%} - -{%- set tgt_cols = dbtvault.create_tgt_cols(src_pk=src_pk, src_nk=src_nk, src_ldts=src_ldts, src_source=src_source, - tgt_pk=tgt_pk, tgt_nk=tgt_nk, tgt_ldts=tgt_ldts, tgt_source=tgt_source, - source=source) -%} - -{%- set tgt_pk = tgt_cols['tgt_pk'] -%} -{%- set tgt_nk = tgt_cols['tgt_nk'] -%} -{%- set tgt_ldts = tgt_cols['tgt_ldts'] -%} -{%- set tgt_source = tgt_cols['tgt_source'] -%} - -{%- set is_union = dbtvault.is_union(source) -%} --- Generated by dbtvault. -SELECT DISTINCT {{ dbtvault.cast([tgt_pk, tgt_nk, tgt_ldts, tgt_source], 'stg') }} -FROM ( - {{ dbtvault.create_source(src_pk, src_nk, src_ldts, src_source, - tgt_pk, tgt_nk, tgt_ldts, tgt_source, - source, is_union) }} -) AS stg -{# If incremental union or single #} -{%- if is_incremental() -%} -LEFT JOIN {{ this }} AS tgt -ON {{ dbtvault.prefix([tgt_pk|first], 'stg') }} = {{ dbtvault.prefix([tgt_pk|last], 'tgt') }} -WHERE {{ dbtvault.prefix([tgt_pk|last], 'tgt') }} IS NULL -{# If an incremental and union load -#} -{% if is_union -%} -AND stg.FIRST_SOURCE IS NULL -{%- endif -%} -{%- endif -%} -{# If a union base-load #} -{%- if is_union and not is_incremental() -%} -WHERE stg.FIRST_SOURCE IS NULL -{%- endif -%} -{%- endmacro -%} \ No newline at end of file diff --git a/macros/tables_deprecated/link_template.sql b/macros/tables_deprecated/link_template.sql deleted file mode 100644 index 6813d08f4..000000000 --- a/macros/tables_deprecated/link_template.sql +++ /dev/null @@ -1,49 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro link_template(src_pk, src_fk, src_ldts, src_source, - tgt_pk, tgt_fk, tgt_ldts, tgt_source, - source) -%} - -{%- set tgt_cols = dbtvault.create_tgt_cols(src_pk=src_pk, src_fk=src_fk, src_ldts=src_ldts, src_source=src_source, - tgt_pk=tgt_pk, tgt_fk=tgt_fk, tgt_ldts=tgt_ldts, tgt_source=tgt_source, - source=source) -%} - -{%- set tgt_pk = tgt_cols['tgt_pk'] -%} -{%- set tgt_fk = tgt_cols['tgt_fk'] -%} -{%- set tgt_ldts = tgt_cols['tgt_ldts'] -%} -{%- set tgt_source = tgt_cols['tgt_source'] -%} - -{%- set is_union = dbtvault.is_union(source) -%} --- Generated by dbtvault. -SELECT DISTINCT {{ dbtvault.cast([tgt_pk, tgt_fk, tgt_ldts, tgt_source], 'stg') }} -FROM ( - {{ dbtvault.create_source(src_pk, src_fk, src_ldts, src_source, - tgt_pk, tgt_fk, tgt_ldts, tgt_source, - source, is_union) }} -) AS stg -{# If incremental union or single #} -{%- if is_incremental() -%} -LEFT JOIN {{ this }} AS tgt -ON {{ dbtvault.prefix([tgt_pk|first], 'stg') }} = {{ dbtvault.prefix([tgt_pk|last], 'tgt') }} -WHERE {{ dbtvault.prefix([tgt_pk|last], 'tgt') }} IS NULL -{# If an incremental and union load -#} -{% if is_union -%} -AND stg.FIRST_SOURCE IS NULL -{%- endif -%} -{%- endif -%} -{# If a union base-load #} -{%- if is_union and not is_incremental() -%} -WHERE stg.FIRST_SOURCE IS NULL -{%- endif -%} -{%- endmacro -%} \ No newline at end of file diff --git a/macros/tables_deprecated/sat_template.sql b/macros/tables_deprecated/sat_template.sql deleted file mode 100644 index a632e93bf..000000000 --- a/macros/tables_deprecated/sat_template.sql +++ /dev/null @@ -1,61 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro sat_template(src_pk, src_hashdiff, src_payload, - src_eff, src_ldts, src_source, - tgt_pk, tgt_hashdiff, tgt_payload, - tgt_eff, tgt_ldts, tgt_source, - source) -%} - -{%- set tgt_cols = dbtvault.create_tgt_cols(src_pk=src_pk, - src_hashdiff=src_hashdiff, src_payload=src_payload, src_eff=src_eff, - src_ldts=src_ldts, src_source=src_source, - tgt_pk=tgt_pk, - tgt_hashdiff=tgt_hashdiff, tgt_payload=tgt_payload, tgt_eff=tgt_eff, - tgt_ldts=tgt_ldts, tgt_source=tgt_source, - source=source) -%} - -{%- set tgt_pk = tgt_cols['tgt_pk'] -%} -{%- set tgt_hashdiff = tgt_cols['tgt_hashdiff'] -%} -{%- set tgt_payload = tgt_cols['tgt_payload'] -%} -{%- set tgt_eff = tgt_cols['tgt_eff'] -%} -{%- set tgt_ldts = tgt_cols['tgt_ldts'] -%} -{%- set tgt_source = tgt_cols['tgt_source'] -%} - -{%- set tgt_cols_list = dbtvault.get_col_list([tgt_pk, tgt_hashdiff, tgt_payload, tgt_eff, tgt_ldts, tgt_source]) -%} - --- Generated by dbtvault. -SELECT DISTINCT {{ dbtvault.cast([tgt_pk, tgt_hashdiff, tgt_payload, tgt_ldts, tgt_eff, tgt_source], 'e') }} -FROM {{ source[0] }} AS e -{% if is_incremental() -%} -LEFT JOIN ( - SELECT {{ dbtvault.prefix(tgt_cols_list, 'd') }} - FROM ( - SELECT {{ dbtvault.prefix(tgt_cols_list, 'c') }}, - CASE WHEN RANK() - OVER (PARTITION BY {{ dbtvault.prefix([tgt_pk|last], 'c') }} - ORDER BY {{ dbtvault.prefix([tgt_ldts|last], 'c') }} DESC) = 1 - THEN 'Y' ELSE 'N' END CURR_FLG - FROM ( - SELECT {{ dbtvault.prefix(tgt_cols_list, 'a') }} - FROM {{ this }} as a - JOIN {{ source[0] }} as b - ON {{ dbtvault.prefix([tgt_pk|last], 'a') }} = {{ dbtvault.prefix([src_pk], 'b') }} - ) as c - ) AS d -WHERE d.CURR_FLG = 'Y') AS src -ON {{ dbtvault.prefix([tgt_hashdiff|last], 'src') }} = {{ dbtvault.prefix([src_hashdiff], 'e') }} -WHERE {{ dbtvault.prefix([tgt_hashdiff|last], 'src') }} IS NULL -{%- endif -%} - -{% endmacro %} diff --git a/macros/tables_deprecated/t_link_template.sql b/macros/tables_deprecated/t_link_template.sql deleted file mode 100644 index e05b4cd2e..000000000 --- a/macros/tables_deprecated/t_link_template.sql +++ /dev/null @@ -1,44 +0,0 @@ -{#- Licensed under the Apache License, Version 2.0 (the "License"); - you may not use this file except in compliance with the License. - You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, software - distributed under the License is distributed on an "AS IS" BASIS, - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - See the License for the specific language governing permissions and - limitations under the License. --#} - -{%- macro t_link_template(src_pk, src_fk, src_payload, src_eff, src_ldts, src_source, - tgt_pk, tgt_fk, tgt_payload, tgt_eff, tgt_ldts, tgt_source, - source) -%} - -{%- set tgt_cols = dbtvault.create_tgt_cols(src_pk=src_pk, src_fk=src_fk, src_payload=src_payload, - src_eff=src_eff, src_ldts=src_ldts, src_source=src_source, - tgt_pk=tgt_pk, tgt_fk=tgt_fk, tgt_payload=tgt_payload, - tgt_eff=tgt_eff, tgt_ldts=tgt_ldts, tgt_source=tgt_source, - source=source) -%} - -{%- set tgt_pk = tgt_cols['tgt_pk'] -%} -{%- set tgt_fk = tgt_cols['tgt_fk'] -%} -{%- set tgt_payload = tgt_cols['tgt_payload'] -%} -{%- set tgt_eff = tgt_cols['tgt_eff'] -%} -{%- set tgt_ldts = tgt_cols['tgt_ldts'] -%} -{%- set tgt_source = tgt_cols['tgt_source'] -%} - -{%- set is_union = dbtvault.is_union(source) -%} --- Generated by dbtvault. -SELECT DISTINCT {{ dbtvault.cast([tgt_pk, tgt_fk, tgt_payload, tgt_eff, tgt_ldts, tgt_source], 'stg') }} -FROM ( - SELECT {{ dbtvault.prefix([src_pk, src_fk, src_payload, src_eff, - src_ldts, src_source], 'stg') }} - FROM {{ source[0] }} AS stg -) AS stg -{% if is_incremental() -%} -LEFT JOIN {{ this }} AS tgt -ON {{ dbtvault.prefix([tgt_pk|first], 'stg') }} = {{ dbtvault.prefix([tgt_pk|last], 'tgt') }} -WHERE {{ dbtvault.prefix([tgt_pk|last], 'tgt') }} IS NULL -{%- endif -%} -{%- endmacro -%} \ No newline at end of file