MySQL에서 JSON 데이터 쿼리
문제:
다음이 포함된 MySQL 테이블이 있습니다. JSON 개체를 저장하는 열입니다. 특정 JSON 필드 값을 기반으로 결과를 필터링하는 쿼리를 실행해야 합니다.
해결책: json_extract 함수 사용
MySQL 5.7 이상에서는 json_extract 함수를 도입했습니다. 열에 저장된 JSON 개체에서 특정 값을 추출합니다. 이를 통해 다음과 같은 쿼리를 수행할 수 있습니다.
<code class="sql">SELECT user_id, json_data FROM articles WHERE json_extract(json_data, '$.title') LIKE '%CPU%';</code>
예:
다음 표를 고려하세요.
<code class="sql">CREATE TABLE articles ( id int NOT NULL, user_id int NOT NULL, json_data json NOT NULL ); INSERT INTO articles (id, user_id, json_data) VALUES (1, 1, '{"url":"https://www.cpubenchmark.net/","title": "CPU Benchmarks"}'), (2, 1, '{"url":"http://www.ebay.com/sch/CPUs-Processors-/164/i.html","title": "Computer and Processors"}'), (3, 2, '{"url":"https://www.youtube.com/watch?v=tntOCGkgt98","title": "Funny Cats Compilation"}');</code>
쿼리 실행 위에 표시된 결과는 다음 결과를 반환합니다.
<code class="sql">+---------+--------------------------------------------------------------------------------------------------+ | user_id | json_data | +---------+--------------------------------------------------------------------------------------------------+ | 1 | {"url":"https://www.cpubenchmark.net/","title": "CPU Benchmarks"} | +---------+--------------------------------------------------------------------------------------------------+</code>
이는 json_extract 함수를 사용하여 MySQL에서 JSON 데이터를 필터링하는 방법을 보여줍니다.
위 내용은 특정 필드 값을 기반으로 MySQL에서 JSON 데이터를 쿼리하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!