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