MySQL LIKE 쿼리의 대소문자 구분
문제:
다음 MySQL 쿼리를 고려하십시오.
SELECT concat_ws(title, description) as concatenated HAVING concatenated LIKE '%SearchTerm%';
그럼에도 불구하고 LIKE 연산자를 사용하면 MyISAM 스토리지 엔진에서 테이블 인코딩이 utf8_general_ci인 경우 검색이 대소문자를 구분하는 것으로 보입니다.
설명:
MyISAM 스토리지 엔진은 대소문자를 사용합니다. utf8_general_ci 인코딩에 저장된 문자열에 대한 둔감한 비교. 그러나 LIKE 연산자는 기본적으로 대소문자 구분 비교를 수행합니다.
최적의 해결 방법:
대소문자 구분 비교를 수행하려면 다음과 같이 BINARY 키워드를 사용하세요.
SELECT .... FROM .... WHERE `concatenated` LIKE BINARY '%SearchTerm%';
피연산자 중 하나가 바이너리인 경우 문자열 비교에서 대소문자가 구분됩니다. 문자열.
대체 해결 방법:
또는 COLLATE 문을 사용하여 로캘별 데이터 정렬을 지정합니다.
SELECT .... FROM .... WHERE `concatenated` like '%SearchTerm%' COLLATE utf8_bin;
이 접근 방식을 사용하면 다음이 가능합니다. 원래 문자 인코딩을 유지하면서 대소문자를 구분하지 않고 비교합니다.
위 내용은 MySQL LIKE 쿼리가 utf8_general_ci 인코딩에서 대소문자를 구분하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!