MySQL의 LIKE 연산자를 사용하여 대소문자를 구분하지 않는 검색 마스터하기
MySQL의 LIKE
연산자는 데이터베이스 열 내 패턴 일치에 매우 중요합니다. 그러나 기본적으로 대소문자를 구분하는 특성으로 인해 문제가 발생할 수 있습니다. 이 가이드는 대소문자를 구분하지 않고 검색을 효율적으로 수행하는 방법을 보여줍니다.
트리 이름을 저장하는 trees
열이 있는 title
이라는 테이블을 생각해 보세요. "elm"이 포함된 모든 나무를 찾으려면 다음과 같은 순진한 접근 방식으로 모든 변형을 캡처할 수 없습니다.
<code class="language-sql">SELECT * FROM trees WHERE trees.title LIKE '%elm%';</code>
이 쿼리는 대소문자를 구분하며 대소문자가 다른 항목(예: "Elm", "ELM")이 누락되었습니다. 해결책은 LOWER()
또는 UPPER()
기능을 사용하는 것입니다.
LOWER()
함수는 비교 전에 열 값을 소문자로 변환하여 대소문자를 구분하지 않는 일치를 활성화합니다.
<code class="language-sql">SELECT * FROM trees WHERE LOWER(trees.title) LIKE '%elm%';</code>
이 수정된 쿼리는 "elm", "ELM" 또는 기타 대소문자 변형이 포함된 레코드를 성공적으로 검색합니다. 마찬가지로 UPPER()
는 동일한 효과를 위해 대문자로 변환됩니다. 데이터 및 쿼리 요구 사항에 가장 적합한 기능을 선택하세요.
위 내용은 MySQL에서 대소문자를 구분하지 않는 LIKE 검색을 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!