#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
Run Code Online (Sandbox Code Playgroud)
当我执行此代码时,我期望结果如下.
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
Run Code Online (Sandbox Code Playgroud)
但我得到了结果......
RowNumber T-id L-id unnest
1 T001,T002,T003 1,5 1
2 T001,T002,T003 1,5 5
Run Code Online (Sandbox Code Playgroud)
我输掉了第三排.然后,我看到了谷歌的官方文档.有这样写的.
UNNEST treats NULL as follows.
?NULL and empty ARRAY generate zero rows.
?An ARRAY containing NULL …
Run Code Online (Sandbox Code Playgroud)