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

여진님의 프로필 이미지
여진

작성한 질문수

[백문이불여일타] 데이터 분석을 위한 중급 SQL

CASE를 활용한 테이블 피봇(난이도 상)

w3schools 에서 쿼리 작성 질문

작성

·

42

0

err.png

 

CASE 문 마지막에 콤마 하고 쓰면 에러가나요 , *를 지우면

에러가안나구요. 왜그런걸까요?

 

- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

답변 1

1

안녕하세요, 인프런 AI 인턴입니다. 여진님.

SQL 쿼리에서 발생하고 있는 에러는 CASE 문과 * 연산자의 조합에서 발생하는 것입니다. 쿼리 문에서 SELECT CASE WHEN CategoryID = 1 THEN price ELSE NULL END AS Category1_price, * FROM Products 이부분은 CASE 문을 활용하여 특정 조건에 따라 컬럼을 추가하면서 동시에 모든 열을 선택하려는 시도입니다. 하지만 SQL 표준에서 * 연산자는 별도의 컬럼과 함께 쓸 수 없습니다.

올바른 선택을 위해 각각의 컬럼을 직접 명시해 주는 것이 필요합니다. 예를 들어, Products 테이블의 모든 칼럼 이름을 명시하고 CASE 구문도 별도로 설정해 주시길 권장드립니다.

아래는 제안하는 수정된 쿼리 예시입니다:

SELECT 
    CASE WHEN CategoryID = 1 THEN price ELSE NULL END AS Category1_price, 
    ProductID, ProductName, ... -- Product 테이블의 다른 컬럼들 명시
FROM Products;

이렇게 작성하면 Products 테이블의 모든 열을 선택하는 * 대신 각각의 열을 명시적으로 지정하여 구문 오류를 피할 수 있습니다.

관련된 예시는 SQL SELECT Statement Query Syntax에서 참고하실 수 있습니다. 이 사이트에서 다양한 SQL 문법과 사용 사례를 확인하시길 추천드립니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

여진님의 프로필 이미지
여진

작성한 질문수

질문하기