Interrogation de données JSON dans les colonnes MySQL
Dans MySQL, vous pouvez stocker des objets JSON dans des colonnes pour stocker des structures de données complexes. Pour interroger efficacement ces champs JSON, vous pourriez rencontrer des difficultés à les intégrer dans les clauses WHERE. Voici une solution :
Solution utilisant json_extract
MySQL 5.7 et versions ultérieures prennent en charge la fonction json_extract, qui vous permet d'extraire des valeurs spécifiques des données JSON. Cette fonction accepte deux arguments : les données JSON et une expression de chemin JSON.
Exemple :
Disons que vous avez une table "articles" avec une colonne "json_data" qui stocke les objets JSON. Pour rechercher des articles dont les titres contiennent « CPU » :
<code class="sql">SELECT user_id, json_data FROM articles WHERE json_extract(json_data, '$.title') LIKE '%CPU%';</code>
Cette requête renverra :
+---------+--------------------------------------------------------------------------------------------------+ | user_id | json_data | +---------+--------------------------------------------------------------------------------------------------+ | 1 | {"url":"https://www.cpubenchmark.net/","title": "CPU Benchmarks"} | +---------+--------------------------------------------------------------------------------------------------+
Explication :
En incorporant json_extract dans vos requêtes, vous pouvez facilement rechercher et filtrer les données JSON dans MySQL, ce qui en fait un outil puissant pour travailler avec des données complexes.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!