해결된 질문
작성
·
86
1
안녕하세요, 섹션3 조건문 type of triangle 문제에서 질문있습니다.
END, 뒤에 *를 붙이면 꼭 에러가 뜹니다. 해커랭크 뿐만아니라 W3스쿨에서도 그러던데 확인 좀 부탁드립니다. 다른 분들도 유사한 질문을 하신 것 같은데, 확인되면 수업 노트 보기에서라도 확인할 수 있게 내용 추가 좀 해주시면 감사하겠습니다.
SELECT *, CASE로 할 경우에는 정상 출력되긴 하더라고요.
답변 2
1
안녕하세요. 답변이 늦어 죄송합니다.
MySQL에서 테이블을 지정하지 않고 단독으로 사용하거나, SELECT의 첫 번째 항목으로만 사용할 수 있습니다. 예를 들어, 아래 처럼 작성하면 같은 결과를 출력해보실 수 있습니다.
1. SELECT의 첫 번째 항목으로 기술
SELECT *
, CASE WHEN categoryid = 1 THEN price ELSE NULL END AS category1_price
FROM Products
2. 테이블을 지정하여 *를 사용
SELECT CASE WHEN categoryid = 1 THEN price ELSE NULL END AS category1_price
, Products.*
FROM Products
수업 노트에 추가해두겠습니다. 좋은 질문 감사합니다.
-1
안녕하세요, 인프런 AI 인턴입니다.
advanceho님, SQL 사용 중에 발생한 에러에 대해 문의해 주셔서 감사합니다.
END
뒤에 *
를 붙이면 MySQL에서 문법 오류가 발생할 수 있습니다. 이는 SQL에서 CASE
문을 끝낼 때 END
뒤에 쉼표를 사용하지 않고, AS
를 통해 별칭을 지정해야 하기 때문입니다. 따라서 다음과 같은 형식으로 수정해 보세요:
SELECT *,
CASE
WHEN 조건 THEN '결과1'
WHEN 조건 THEN '결과2'
ELSE '기타'
END AS triangle_type
FROM triangles;
이 방식으로 작성하면 에러가 발생하지 않고, 원하는 결과를 출력할 수 있을 것입니다. 더불어, 섹션 노트에 이와 같은 내용을 추가하여 다른 학습자들에게 도움이 되도록 제안해주신 부분 감사합니다.
혹시 더 궁금한 사항이 있으면 언제든지 문의해 주세요!