직렬화된 배열 필터링을 사용한 MySQL 쿼리
MySQL 데이터베이스에서는 직렬화된 배열 내의 특정 항목을 기반으로 레코드를 검색해야 할 수도 있습니다. 필드에 저장된 배열입니다. 그러나 직렬화된 배열 내의 직접 항목 비교는 SQL 언어에서 지원되지 않습니다.
그럼에도 불구하고 이 문제를 해결하기 위한 두 가지 잠재적 접근 방식이 있습니다:
문자열로 직렬화된 배열
직렬화된 배열은 기본적으로 문자열이므로 LIKE 절을 활용하여 레코드를 일치시키고 선택할 수 있습니다. 예를 들면 다음과 같습니다.
SELECT * FROM table WHERE (an item in my array) LIKE '%$n%'
이 접근 방식에는 PHP의 unserialize() 함수를 사용하여 직렬화된 배열을 문자열로 재구성하고 배열에 인덱싱하여 원하는 항목을 확인한 다음 serialize()를 사용하여 다시 직렬화하는 작업이 포함됩니다. .
데이터베이스 정규화
빈번한 쿼리로 인해 직렬화된 배열 내의 개별 항목에 액세스해야 하는 경우 각 항목을 별도의 행으로 저장하여 데이터 구조를 정규화하는 것이 좋습니다. 관련 테이블에서 이는 잠재적으로 복잡한 문자열 구문 분석 및 LIKE 작업이 필요하지 않으므로 훨씬 더 나은 성능과 쿼리 유연성을 제공합니다.
위 내용은 직렬화된 배열 내의 항목을 기반으로 MySQL 레코드를 필터링하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!