gpt4 book ai didi

sql - Snowflake 使用 flatten 进行数组展平返回未知函数

转载 作者:行者123 更新时间:2023-12-02 01:58:03 29 4
gpt4 key购买 nike

我有一个返回时间戳数组的函数。我想将这些时间戳转换为 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

函数是:

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 是表函数,不是标量函数。它在 SQL 中作为标量函数而不是表函数被调用,这就是 Snowflake 报告找不到该函数的原因。

如果您更改此行以将其用作表函数,它似乎可以执行您想要的操作:

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

关于sql - Snowflake 使用 flatten 进行数组展平返回未知函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69380528/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com