직렬화된 배열 내의 항목을 기반으로 MySQL 레코드를 필터링하려면 어떻게 해야 합니까?

DDD
풀어 주다: 2024-11-07 16:54:03
원래의
574명이 탐색했습니다.

How can I filter MySQL records based on an item within a serialized array?

직렬화된 배열 필터링을 사용한 MySQL 쿼리

MySQL 데이터베이스에서는 직렬화된 배열 내의 특정 항목을 기반으로 레코드를 검색해야 할 수도 있습니다. 필드에 저장된 배열입니다. 그러나 직렬화된 배열 내의 직접 항목 비교는 SQL 언어에서 지원되지 않습니다.

그럼에도 불구하고 이 문제를 해결하기 위한 두 가지 잠재적 접근 방식이 있습니다:

문자열로 직렬화된 배열

직렬화된 배열은 기본적으로 문자열이므로 LIKE 절을 활용하여 레코드를 일치시키고 선택할 수 있습니다. 예를 들면 다음과 같습니다.

SELECT * FROM table WHERE (an item in my array) LIKE '%$n%'
로그인 후 복사

이 접근 방식에는 PHP의 unserialize() 함수를 사용하여 직렬화된 배열을 문자열로 재구성하고 배열에 인덱싱하여 원하는 항목을 확인한 다음 serialize()를 사용하여 다시 직렬화하는 작업이 포함됩니다. .

데이터베이스 정규화

빈번한 쿼리로 인해 직렬화된 배열 내의 개별 항목에 액세스해야 하는 경우 각 항목을 별도의 행으로 저장하여 데이터 구조를 정규화하는 것이 좋습니다. 관련 테이블에서 이는 잠재적으로 복잡한 문자열 구문 분석 및 LIKE 작업이 필요하지 않으므로 훨씬 더 나은 성능과 쿼리 유연성을 제공합니다.

위 내용은 직렬화된 배열 내의 항목을 기반으로 MySQL 레코드를 필터링하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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