> 데이터 베이스 > MySQL 튜토리얼 > MySQL의 JSON 배열 내에서 요소를 효율적으로 검색하는 방법은 무엇입니까?

MySQL의 JSON 배열 내에서 요소를 효율적으로 검색하는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2024-11-29 11:59:09
원래의
302명이 탐색했습니다.

How to Efficiently Search for Elements within JSON Arrays in MySQL?

MySQL에서 JSON 배열 검색

배열이 포함된 "data"라는 JSON 열이 있는 MySQL 테이블이 있다고 가정합니다. 배열 요소 중 하나가 2보다 큰 모든 행을 검색하려고 합니다.

쿼리

SELECT * from my_table
WHERE JSON_EXTRACT(data, '$[*]') > 2;
로그인 후 복사

는 배열 값에 관계없이 항상 true로 평가되므로 잘못된 결과를 반환합니다. .

배열에서 정수를 검색하려면:

JSON_CONTAINS('[1,2,3,4,5]','7','$')  # Returns: 0
JSON_CONTAINS('[1,2,3,4,5]','1','$')  # Returns: 1
로그인 후 복사

배열에서 문자열을 검색하려면 배열:

JSON_CONTAINS('["a","2","c","4","x"]','"x"','$')  # Returns: 1
JSON_CONTAINS('["1","2","3","4","5"]','"7"','$')  # Returns: 0
로그인 후 복사

귀하의 시나리오에서는 쿼리를 사용합니다.

SELECT * from my_table
WHERE JSON_CONTAINS(data, '2', '$');
로그인 후 복사

이 쿼리는 "데이터" 열에 요소가 2보다 큰 배열이 포함된 모든 행을 선택합니다.

위 내용은 MySQL의 JSON 배열 내에서 요소를 효율적으로 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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