w3schools 에서 쿼리 작성 질문

CASE 문 마지막에 콤마 하고 쓰면 에러가나요 , *를 지우면
에러가안나구요. 왜그런걸까요?
- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
Câu trả lời 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 문법과 사용 사례를 확인하시길 추천드립니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
리트코드 1280. Students and Examinations
0
74
3
16강 LEFT JOIN 리트코드 (183. Customers Who Never Order) 관련 질문
0
89
2
African Cities 문제관련 질문
0
53
1
SQL 코딩테스트 질문
0
206
1
HACKER RANK에서 문제찾기
0
94
2
강의 자료 다운로드
0
90
2
Asian population 문제가 없어요
0
76
2
INNER JOIN 에서 A.키 쓸때 빨간 색 나오고 'dause'
0
65
2
별칭 관련해서 질문 있습니다.
0
78
2
rising temperature 문제 질문
0
98
2
해커랭크 TOP EARNERS 문제 질문
0
98
1
ON 뒤에 질문
0
94
2
INNER JOIN 질문. 강의와 결과값이 다릅니다.
0
196
3
END, 뒤에 * 붙이면 에러가 뜹니다
1
203
2
CustomerID가 중복되서 나타나요
0
232
3
별칭이 전체 테이블을 못 불러와요.
0
142
2
CASE WHEN 쿼리 오류 문의
1
324
3
CASE문제풀이 질문
0
124
1
Customers Who Never Order 풀다가 Alias관련 질문사항
0
136
1
Average Population 질문
0
128
1
Revising Aggregations - The Count Function 질문
0
103
1
Average Population of Each Continent 에대해서 질문
0
191
3
INNER JOIN 할 때 NULL 값이 안보일 수도 있나요?
0
328
1
new_category 그룹핑 시 에러 (밑에분과 동일)
1
184
1

