繁体   English   中英

雪花使用展平阵列展平返回未知 function

[英]Snowflake using flatten for array flattening returning unknown function

我有一个 function 返回一个时间戳数组。 我想将这些时间戳转换为 yyyy-mm-dd 格式的日期。 我想展平返回的数组列,但我得到:

SQL compilation error: Unknown function FLATTEN

当我跑步时:

with cte as (SELECT 
    array_construct('2021-09-10'::date,'2021-09-11'::date,'2021-09-12'::date) AS array
    ,'2021-09-11'::date AS max_date
    ,date_filter
        (
          '2021-09-12'::date,
          array_construct('2021-09-10'::date,'2021-09-11'::date,'2021-09-12'::date)
          
        ) as dates )
        
        select flatten(cte.dates) from cte

Function 是:

CREATE OR REPLACE FUNCTION date_filter (max_date DATE, date_list ARRAY)
  RETURNS ARRAY
  LANGUAGE JAVASCRIPT
  AS $$
  var dates = DATE_LIST;
  return  dates.filter(date => date < MAX_DATE);
  $$
  ;

flatten是表 function,而不是标量 function。它在 SQL 中被称为标量 function 而不是表 function,这就是 Snowflake 报告找不到 84.654088 的原因

如果您更改此行以将其用作表 function,它似乎可以满足您的要求:

select * from cte, table (flatten(cte.dates))

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM