>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 분음 부호를 구분하지 않는 검색을 수행하는 방법은 무엇입니까?

MySQL에서 분음 부호를 구분하지 않는 검색을 수행하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-01 12:38:02958검색

How to Perform Diacritic Insensitive Searches in MySQL?

MySQL 발음 구별 부호를 구분하지 않는 검색

악센트가 포함된 스페인어 단어로 작업할 때 발음 구별 부호를 고려하면서 검색 쿼리를 수행하는 것이 어려울 수 있습니다. . 이 문서에서는 문자 집합과 데이터 정렬의 조합을 사용하여 MySQL 데이터베이스에서 발음 구별 부호를 구분하지 않는 검색을 실행하는 솔루션을 제공합니다.

제공된 예:

$result = mysql_query("SELECT * FROM $lookuptable WHERE disabled = '0' AND name LIKE '%$q%' OR productCode LIKE '%$q%' LIMIT $sugglimit");

이는 발음 구별 부호 차이를 설명하지 않으며, 그럴 수 있습니다. "lapiz"를 검색할 때 "lápiz"와 같은 단어가 포함된 결과를 제외합니다.

발음 부호를 구분하지 않으려면 MySQL 명령 SET NAMES를 활용하여 데이터베이스 연결에 대한 특정 문자 집합과 데이터 정렬을 지정할 수 있습니다. 문자 세트를 latin1로 설정하고 대조를 악센트를 구분하지 않는 것으로 설정하면 쿼리는 악센트가 있는 단어와 없는 단어를 모두 일치시킬 수 있습니다.

예:

SET NAMES latin1;
SELECT 'lápiz' LIKE 'lapiz';

이 쿼리는 "lápiz"와 "lapiz"가 동일하지 않음을 나타내는 0을 반환합니다.

utf8 문자 집합으로 전환하면:

SET NAMES utf8;
SELECT 'lápiz' LIKE 'lapiz';

쿼리는 1을 반환하여 이를 보여줍니다. 검색이 이제 발음 구별 부호를 구분하지 않습니다.

패턴이 UTF-8 문자열과 일치해야 함을 명시적으로 지정하려면 _utf8 접두사를 사용할 수 있습니다.

SET NAMES latin1;
SELECT _utf8'lápiz' LIKE _utf8'lapiz';

이 예에서 쿼리는 1을 반환하여 latin1 문자 집합을 명시적으로 사용하는 경우에도 분음 부호를 구분하지 않음을 확인합니다.

자세한 내용은 문자 집합 지원에 대한 MySQL 설명서를 참조하세요.

위 내용은 MySQL에서 분음 부호를 구분하지 않는 검색을 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.