>데이터 베이스 >MySQL 튜토리얼 >MySQL의 쉼표로 구분된 필드에서 특정 값을 효율적으로 검색하려면 어떻게 해야 합니까?

MySQL의 쉼표로 구분된 필드에서 특정 값을 효율적으로 검색하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-08 01:26:02946검색

How Can I Efficiently Search for a Specific Value in a Comma-Separated Field in MySQL?

MySQL에서 쉼표로 구분된 값 검색

다른 테이블에 대한 참조로 쉼표로 구분된 목록이 포함된 테이블을 만나는 일은 드문 일이 아닙니다. 이러한 상황은 불리한 것으로 인정되지만 LIKE 쿼리를 사용하여 필드 내에서 검색을 시도할 때 문제가 됩니다.

특정 값을 검색하려고 할 때 '%1%'와 같은 LIKE 쿼리를 사용하면 다음과 같은 결과가 발생할 수 있습니다. 이러한 ID가 있는 일반적인 범위(10-20)로 인해 긍정적인 일치 항목이 많습니다. 이 문제를 해결하려면 일치 항목을 %,1,%로 검색하는 것이 좋습니다. 그러나 이 접근 방식은 목록의 시작이나 끝 부분에 있는 ID를 고려하지 못합니다.

실행 가능한 솔루션은 FIND_IN_SET 함수를 활용하는 것입니다. 이 함수를 사용하면 사용자가 쉼표로 구분된 필드 내에서 값을 검색할 수 있습니다. FIND_IN_SET('1', field)를 사용하여 쿼리는 필드에 '1' 값이 포함된 레코드를 식별합니다. 이 기능은 쉼표로 구분된 목록에서 특정 값을 검색하는 문제를 효과적으로 해결하고 데이터베이스 쿼리의 정확성을 향상시킵니다.

위 내용은 MySQL의 쉼표로 구분된 필드에서 특정 값을 효율적으로 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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