인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

전성배님의 프로필 이미지

작성한 질문수

BigQuery(SQL) 활용편(퍼널 분석, 리텐션 분석)

1-5. 데이터 PIVOT하기 : MAX(IF( ~ )) 활용

1-5 예제용 학생 점수 데이터 테이블 생성 시 오류 발생

해결된 질문

작성

·

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의 형태를 띈다고 생각해주시면 좋을 것 같네요

전성배님의 프로필 이미지
전성배
질문자

자세히 알려주셔서 감사합니다!!