작성
·
50
0
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 문법과 사용 사례를 확인하시길 추천드립니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.