sql - 雪花使用 flatten 进行数组展平返回未知函数
问题描述
我有一个返回时间戳数组的函数。我想将这些时间戳转换为 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))
推荐阅读
- javascript - 如何检查两位数数组是否与对象数组的某个部分相同?
- openssl - 如何使用 openssl 生成证书
- dialogflow-es - 错误的意图正在触发对话流中不适当的用户输入
- python - 如何通过 Python 创建表在 sqlite3 中显示表
- typescript - Firebase:在这种情况下,我每次发布内容时都需要发送 uid 吗?
- c - C - 如何通过函数增加指向字符串的指针?
- c# - ASP.NET Webservice-SessionState 不超时
- flutter - Flutter Wrap 溢出的文本
- firebase - 拦截复杂业务逻辑的 Cloud Firestore 写入操作
- algorithm - 计算二维对数组中的反转