해결된 질문
작성
·
62
0
안녕하세요 카일님
1-5 학습 중 PIVOT 예제용 TABLE을 만들어 보려고 하였습니다.
결론부터 말씀드리면 TABLE 생성에 성공하였어요.
다만 궁금한 것은 제가 겪은 오류에 대한 해석이 올바른 것인지 확인 받고 싶어서 질문 드립니다.
1-4 강에 있던 array_exercise 생성 구문을 참고하여 아래와 같은 구문으로 실행하였더니 생성되지 않았습니다.
가장 안쪽의 select 부터 실행하면서 찾아보니 최하단의 UNION ALL이 원인이었더라구요.
UNION ALL 은 아래에도 추가 ROW를 입력해야 할 때, 한 행으로 밀어넣는 명령어이므로, 마지막 행 다음에는 넣지 말아야 한다. 넣을 경우 그 뒤에 추가적인 데이터의 입력을 요구하나, 데이터가 없으므로 실행이 되지 않는 것이다.
라고 이해했는데, 맞게 이해했을까요?
CREATE OR REPLACE TABLE `advanced.grade` AS
SELECT student, grades
FROM (
SELECT
'A' AS student,
ARRAY<STRUCT<subject STRING, score INT64>>[
STRUCT('수학', 80),
STRUCT('영어', 90),
STRUCT('과학', 85)
] AS grades
UNION ALL
SELECT
'B',
ARRAY<STRUCT<subject STRING, score INT64>>[
STRUCT('수학', 75),
STRUCT('영어', 95),
STRUCT('과학', 80)
]
UNION ALL
)
답변 1
1
성배님 안녕하세요
UNION ALL 은 위에 있는 내용과 아래의 쿼리의 결과를 합치는 문법이라 생각하시면 됩니다. 그래서 아래에 UNION ALL만 있으면 그 아래 내용이 없어서 오류가 발생하게 됩니다..!
SELECT 문 # A
UNION ALL
SELECT 문 # B
위 경우에 A의 결과 + B의 결과를 합친다는 의미입니다. 맨 아래에 UNION ALL을 쓴다면 또 무언가를 추가하겠다는 의미로 SQL 엔진이 이해합니다. 그런데 뒤에 무언가가 나오지 않아서 오류를 발생시킵니다
말씀해주신 "마지막 행 다음에는 넣지 말아야 한다. 넣을 경우 그 뒤에 추가적인 데이터의 입력을 요구하나, 데이터가 없으므로 실행이 되지 않는 것이다"도 비슷한 어감이지만, 제가 설명한다면 "UNION ALL의 문법을 지키지 않아서 발생한 오류"라고 말씀드릴 것 같네요. UNION ALL의 문법이 A UNION ALL B의 형태를 띈다고 생각해주시면 좋을 것 같네요
자세히 알려주셔서 감사합니다!!