1-5 예제용 학생 점수 데이터 테이블 생성 시 오류 발생
안녕하세요 카일님
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의 형태를 띈다고 생각해주시면 좋을 것 같네요
최종 과제 제출
0
81
3
BigQuery 활용편 18강 질문있습니다!
0
83
1
리텐션 공부하다가 궁금한게 생겨 질문드립니다
0
83
2
안녕하세요 강사님 코호트 쿼리 공부하다가 의문점이 생겨서 문의드립니다
0
74
2
biquery 테이블 생성 오류 이슈
0
55
2
동일하게 쿼리를 작성했는데 화면과 다른 값이 나옵니다
0
73
2
[과제] 퍼널 PIVOT 테이블 작성하기
0
67
2
array 등
0
63
2
N day 리텐션 쿼리 관련 질문
0
63
2
이동평균 계산 시 order by 기본값은 뭔가요?
0
68
2
윈도우 연습문제 1번 질문
0
65
1
user_id에 NULL이 나오는데 정상인가요?
0
71
2
3-13 리텐션 과제 제출
0
94
2
최종 과제 제출
0
130
3
weekly retention 구하기 과제
0
90
2
1-9. 피벗 쿼리 작성
0
81
2
app_logs 테이블 생성 문제
0
73
2
Weekly Retention 구하기 완성하였습니다.
0
77
2
[과제] 퍼널 쿼리(피벗테이블 적용) 작성 완료
0
106
2
3-7 Weekly, Monthly Retention 쿼리 작성
0
92
2
정성 데이터 분석 방법 문의
0
165
1
최종 과제 제출
0
108
3
1-6 예시 문제 풀이
0
69
2
최종과제 제출
0
145
2





