>  기사  >  데이터 베이스  >  특정 필드 값을 기반으로 MySQL에서 JSON 데이터를 쿼리하려면 어떻게 해야 합니까?

특정 필드 값을 기반으로 MySQL에서 JSON 데이터를 쿼리하려면 어떻게 해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2024-10-26 10:34:02383검색

How can I Query JSON Data in MySQL Based on Specific Field Values?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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