MySQL LIKE 쿼리가 utf8_general_ci 인코딩에서 대소문자를 구분하는 이유는 무엇입니까?

Susan Sarandon
풀어 주다: 2024-11-09 18:05:02
원래의
386명이 탐색했습니다.

Why are MySQL LIKE Queries Case-Sensitive with utf8_general_ci Encoding?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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