1
#StandardSQL
WITH tableA AS (
SELECT ["T001", "T002", "T003"] AS T_id, [1, 5] AS L_id
UNION ALL
SELECT ["T008", "T009"] AS T_id, NULL AS L_id
)
SELECT * FROM tableA, UNNEST(L_id) AS unnest
当我执行此代码时,我预计结果如下。Google BigQuery,当使用'unnest'功能时,我丢失了空行
RowNumber T-id L-id unnest
1 T001,T002,T003 1,5 1
2 T001,T002,T003 1,5 5
3 T004,T005 NULL NULL
但我下的结果得到...
RowNumber T-id L-id unnest
1 T001,T002,T003 1,5 1
2 T001,T002,T003 1,5 5
我失去了第三排。 然后,我看到谷歌的官方文件。有这样写的。
UNNEST treats NULL as follows.
・NULL and empty ARRAY generate zero rows.
・An ARRAY containing NULL generates a row containing a NULL value.
但我不想丢失我的空行。
如何保持空行?
请告诉我的解决方案...
嗨艾略特,看起来像关键字'unnest'保留,得到消息“意外的关键字UNNEST”。也许它需要用符号或被称为“unnest_”。 –
谢谢你指出。我现在修好了。 –
谢谢你,艾略特! 我只是照你说的做,我可以得到我想要的结果。 –