ホームページ > データベース > mysql チュートリアル > PostgreSQL で JSON および JSONB データをクエリするにはどうすればよいですか?

PostgreSQL で JSON および JSONB データをクエリするにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2025-01-18 19:32:02
オリジナル
258 人が閲覧しました

How to Query JSON and JSONB Data in PostgreSQL?

PostgreSQL での JSON データ型フィールドのクエリ

PostgreSQL 9.2 では JSON データ型が導入されましたが、JSON レコード内のフィールドの高度なクエリにはカスタム関数が必要でした。 PostgreSQL 9.3 では、これらの機能が演算子と関数によって拡張されました。

具体的には、「data」という名前の JSON 列を持つテーブルの場合:

Postgres 9.3:

  • レコードを検索するにはname:
SELECT object
FROM   json_tbl
     , json_array_elements(data) AS object
WHERE  object->>'name' = 'Toby';
ログイン後にコピー

Postgres 9.4:

  • JSON データをネイティブ Postgres 型で保存する jsonb データ型が導入されました。
  • GIN または他のタイプを使用したインデックスは改善される可能性がありますパフォーマンス。

Postgres 9.5:

  • 完全な jsonb 関数と演算子。
  • jsonb データを操作および表示するための追加関数。

Postgres 12:

  • SQL/JSON パス言語サポート
  • JSON パスを使用して名前でレコードを検索するには:
SELECT jsonb_path_query_first(data, '$[*] ? (@.name == "Toby")') AS object
FROM   jsonb_tbl
WHERE  data @> '[{ "name": "Toby"}]';  -- optional for indexing
ログイン後にコピー
  • または同等のもの:

    ...
    WHERE  data @@ '$[*].name == "Toby"';
    ログイン後にコピー

追加リソース:

  • [Postgres 9.3 JSON 機能](https://www.postgresql.org/docs/9.3/) static/)
  • [Postgres JSONBデータ型](https://www.postgresql.org/docs/current/static/datatype-json.html)
  • [Postgres 12 JSON パスのサポート](https://www.postgresql.org/docs /12/static/functions-json.html)
  • [Github PostSQL]関数](https://github.com/daviddias/postsด้วย)

以上がPostgreSQL で JSON および JSONB データをクエリするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート