해결된 질문
작성
·
32
0
SELECT DISTINCT CITY
FROM station
WHERE lEFT(city,1) NOT IN ('a', 'i', 'e', 'o', 'u')
AND RIGHT(city,1) NOT IN ('a', 'i', 'e', 'o', 'u')
위와 같이 엑셀처럼 변경해서 해봤는데
구동은 되서 Submit code 했습니다.
그런데 LIKE와 = 처럼 특정상황에서
=가 더 검색이 빠르듯이
WHERE city NOT LIKE 'a%'
AND city NOT LIKE ...
에 비해서 연산속도나 가독성을 고려하면
NOT IN을 사용하는게 좋을까요?
아니면 NOT LIKE 형식으로 나열하는게 좋을까요?
질문드립니다.
감사합니다.
답변 1
0
안녕하세요, 인프런 AI 인턴입니다. 개발너구리님 질문 주셔서 감사합니다.
SQL에서 IN
과 LIKE
는 각각의 사용 용도에 따라 다른 결과를 가져올 수 있습니다. IN
은 특정 값의 목록에 포함되는지 확인할 때 사용하며, LIKE
는 문자열 패턴과 일치하는지를 확인할 때 사용합니다.
성능 측면: 일반적으로 IN
구문은 LIKE
보다 성능이 좋다고 알려져 있습니다. 특히, 단순히 앞글자나 끝 글자를 확인한다면 IN
으로 체크하는 것이 더 빠를 수 있습니다. 하지만 데이터베이스의 인덱싱과 최적화에 따라 실제 응답 시간은 다를 수 있습니다.
가독성: IN
구문은 코드의 가독성을 높이는 데 도움을 줄 수 있습니다. 특히 여러 값을 입력해야 할 경우 리스트로 묶어 쉽게 볼 수 있기 때문입니다.
구체적인 요구사항: LIKE
는 문자열 패턴 매칭에 강점이 있어, 복잡한 패턴 매칭이 필요한 경우 주로 사용됩니다. 예를 들어 LIKE '%pattern%'
처럼 특정 패턴이 포함된 데이터를 찾는 경우에는 LIKE
가 필요합니다.
이와 관련된 유사한 질문을 아래 URL에서 확인하실 수 있습니다:
- WHERE 절의 IN과 LIKE 사용방법 비교
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.