MySQL에서 LIKE 연산자를 사용하여 대소문자를 구분하지 않고 검색하려면 어떻게 해야 합니까?

Barbara Streisand
풀어 주다: 2024-11-09 03:48:02
원래의
240명이 탐색했습니다.

How can I achieve case-insensitive search with LIKE operator in MySQL?

MySQL 쿼리: 대소문자 구분 수수께끼

MySQL 쿼리 작업 시 정확한 검색 결과를 보장하려면 대소문자 구분을 고려하는 것이 중요합니다. 그러나 utf8_general_ci 인코딩과 함께 LIKE 연산자를 사용하면 대소문자를 구분하는 검색 동작으로 이어지는 일반적인 문제가 발생합니다.

이 문제를 해결하기 위해 대소문자를 구분하지 않을 수 있는 몇 가지 솔루션이 있습니다.

1. 이진 문자열 비교:

SELECT .... FROM .... WHERE `concatenated` LIKE BINARY '%SearchTerm%';
로그인 후 복사

BINARY를 사용하면 이진 문자열이 대소문자에 관계없이 바이트 시퀀스로 처리되므로 문자열 비교에서 대소문자를 구분하지 않게 됩니다.

2. utf8_bin을 사용한 COLLATE 절:

SELECT ....
FROM ....
WHERE `concatenated` like '%SearchTerm%' COLLATE utf8_bin;
로그인 후 복사

COLLATE 절은 비교를 위해 특정 문자 집합과 데이터 정렬을 지정합니다. utf8_bin은 utf8 데이터에 대해 대소문자를 구분하지 않는 비교를 보장합니다.

성능 고려 사항:

BINARY 또는 COLLATE를 사용하면 쿼리 성능에 영향을 미칠 수 있습니다. BINARY 비교가 더 효율적일 수 있는 반면 COLLATE는 추가 처리 오버헤드를 발생시킬 수 있습니다. 따라서 최적의 솔루션은 특정 사용 시나리오에 따라 달라질 수 있습니다.

위 내용은 MySQL에서 LIKE 연산자를 사용하여 대소문자를 구분하지 않고 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿