Maison > base de données > tutoriel mysql > Comment interroger des données JSON et JSONB dans PostgreSQL ?

Comment interroger des données JSON et JSONB dans PostgreSQL ?

Mary-Kate Olsen
Libérer: 2025-01-18 19:32:02
original
258 Les gens l'ont consulté

How to Query JSON and JSONB Data in PostgreSQL?

Interrogation des champs de type de données JSON dans PostgreSQL

PostgreSQL 9.2 a introduit le type de données JSON, mais l'interrogation avancée des champs dans les enregistrements JSON nécessitait des fonctions personnalisées. PostgreSQL 9.3 a étendu ces capacités avec des opérateurs et des fonctions.

Plus précisément, pour une table avec une colonne JSON nommée « data » :

Postgres 9.3 :

  • Pour rechercher un enregistrement par nom :
SELECT object
FROM   json_tbl
     , json_array_elements(data) AS object
WHERE  object->>'name' = 'Toby';
Copier après la connexion

Postgres 9.4 :

  • Introduit le type de données jsonb, qui stocke les données JSON dans les types Postgres natifs.
  • Les index utilisant GIN ou d'autres types peuvent s'améliorer performances.

Postgres 9.5 :

  • Fonctions et opérateurs jsonb complets.
  • Plus de fonctions pour manipuler et afficher les données jsonb.

Postgres 12 :

  • Prise en charge du langage de chemin SQL/JSON
  • Pour rechercher un enregistrement par nom à l'aide du chemin JSON :
SELECT jsonb_path_query_first(data, '$[*] ? (@.name == "Toby")') AS object
FROM   jsonb_tbl
WHERE  data @> '[{ "name": "Toby"}]';  -- optional for indexing
Copier après la connexion
  • Ou équivalent :

    ...
    WHERE  data @@ '$[*].name == "Toby"';
    Copier après la connexion

Supplémentaire ressources :

  • [Fonctionnalité JSON Postgres 9.3](https://www.postgresql.org/docs/9.3/static/)
  • [Type de données JSONB Postgres](https:/ /www.postgresql.org/docs/current/static/datatype-json.html)
  • [Postgres 12 Prise en charge du chemin JSON](https://www.postgresql.org/docs/12/static/functions-json.html)
  • [Fonctions Github PostSQL](https://github.com/daviddias/ messagesด้วย)

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal