微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用DBT中用于Redshift的宏连接列

如何解决使用DBT中用于Redshift的宏连接列

我想在DBT for Redshift中使用column1 ^^ column2 ^^ ...语法连接几列。如果在列@@中使用NULL值,则结果为f。 @@ ^^ @@。我发现以下用于串联的宏:

{% macro safe_concat(field_list) %}
  {# Takes an input list and generates a concat() statement with each argument in the list safe_casted to a string and wrapped in an ifnull() #}
  concat({% for f in field_list %}
    ifnull(safe_cast({{ f }} as string),'@@')
    {% if not loop.last %},{% endif %}
  {% endfor %})
{% endmacro %}

当我在select语句中使用它时:

select
  {{ safe_concat([street,city]) }} as address_key
from source

我收到以下错误。这与我使用的代码有关吗?

Database Error in model address (models/address.sql)
  Syntax error at or near "as"
  LINE 32:     ifnull(safe_cast( as string),'@@')

解决方法

在宏中调用列名时,尝试将其用引号引起来-我认为它试图传递变量streetcity(因为您已经在花括号中了),尚不存在,因此正在评估None

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。