MysqlクエリJSON結果に関連する関数の概要

MysqlクエリJSON結果に関連する関数の概要

JSON 形式のフィールドは、MySQL 5.7 で追加された新しい属性ですが、基本的には文字列としてデータベースに保存されます。初めて触れたときは、フィールドをクエリする $.xx メソッドしか知りませんでした。ほとんどの場合、これで十分であり、残りはプログラムに任せられるからです。しかし、最近の操作の中には、より複雑なクエリ操作が必要なものもあったので、すぐにもっと多くの方法を学びました。

JSON_EXTRACT(json_doc [,パス])

クエリフィールド

mysql> @j = '{"name":"wxnacy"}' を設定します。
mysql> JSON_EXTRACT(@j, '$.name') を選択します。
+----------------------------+
| JSON_EXTRACT(@j, '$.name') |
+----------------------------+
| 「wxnacy」|
+----------------------------+

より簡潔な方法もありますが、テーブルをクエリするときにのみ使用できます。

mysql> テストから ext -> '$.name' を選択します。
+-----------------+
| 拡張子 -> '$.name' |
+-----------------+
| 「wxnacy」|
+-----------------+

$. の後には、JSON 形式を使用して配列などのデータを取得できます。

mysql> @j = '{"a": [1, 2]}' を設定します。
mysql> JSON_EXTRACT(@j, '$.a[0]')を選択します。
+----------------------------+
| JSON_EXTRACT(@j, '$.a[0]') |
+----------------------------+
| 1 |
+----------------------------+

JSON_DEPTH(json_doc)

JSONの深さを計算します。計算方法は{} []です。記号がある場合はレイヤーです。記号の下にデータがある場合は、さらにレイヤーが追加されます。複雑なJSONは最も深いものまで計算されます。公式ドキュメントではnull値の深さは0と書かれていますが、実際の効果はそうではありません。いくつか例を挙げます

JSON_LENGTH(json_doc [, パス])

最も外側の JSON または指定されたパスの長さを計算します。スカラーの長さは 1 です。配列の長さは配列要素の数であり、オブジェクトの長さはオブジェクト メンバーの数です。

mysql> JSON_LENGTH('[1, 2, {"a": 3}]')を選択します。
+---------------------------------+
| JSON_LENGTH('[1, 2, {"a": 3}]') |
+---------------------------------+
| 3 |
+---------------------------------+
mysql> JSON_LENGTH('{"a": 1, "b": {"c": 30}}')を選択します。
+-----------------------------------------+
| JSON_LENGTH('{"a": 1, "b": {"c": 30}}') |
+-----------------------------------------+
| 2 |
+-----------------------------------------+
mysql> JSON_LENGTH('{"a": 1, "b": {"c": 30}}', '$.b') を選択します。
+------------------------------------------------+
| JSON_LENGTH('{"a": 1, "b": {"c": 30}}', '$.b') |
+------------------------------------------------+
| 1 |
+------------------------------------------------+

JSON_TYPE(json_doc)

JSON 値の型を示す utf8mb4 文字列を返します。 これは、次に示すように、オブジェクト、配列、またはスカラー型になります。

mysql> SET @j = '{"a": [10, true]}';
mysql> JSON_TYPE(@j) を選択します。
+---------------+
| JSON_TYPE(@j) |
+---------------+
| オブジェクト |
+---------------+
mysql> JSON_TYPE(JSON_EXTRACT(@j, '$.a'))を選択します。
+------------------------------------+
| JSON_TYPE(JSON_EXTRACT(@j, '$.a')) |
+------------------------------------+
| 配列 |
+------------------------------------+
mysql> JSON_TYPE(JSON_EXTRACT(@j, '$.a[0]'))を選択します。
+---------------------------------------+
| JSON_TYPE(JSON_EXTRACT(@j, '$.a[0]')) |
+---------------------------------------+
| 整数 |
+---------------------------------------+
mysql> JSON_TYPE(JSON_EXTRACT(@j, '$.a[1]'))を選択します。
+---------------------------------------+
| JSON_TYPE(JSON_EXTRACT(@j, '$.a[1]')) |
+---------------------------------------+
| ブール値 |
+---------------------------------------+

戻り値の型

純粋なJSON型:

  • オブジェクト: JSONオブジェクト
  • 配列: JSON配列
  • ブール値: JSON の真偽テキスト
  • NULL: JSON nullリテラル

番号タイプ:

  • INTEGER: MySQL TINYINT、SMALLINT、MEDIUMINT、および INT と BIGINT スカラー
  • DOUBLE: MySQL DOUBLE FLOAT スカラー
  • DECIMAL: MySQL DECIMAL および NUMERIC スカラー

時間タイプ:

  • DATETIME: MySQL DATETIME および TIMESTAMP スカラー
  • 日付: MySQL DATE スカラー
  • TIME: MySQL TIME スカラー

文字列型:

STRING: MySQL utf8 文字型スカラー: CHAR、VARCHAR、TEXT、ENUM、SET

バイナリタイプ:

BLOB: MySQL バイナリ型スカラー (BINARY、VARBINARY、BLOB、BIT など)

その他すべてのタイプ:

OPAQUE (生ビット)

JSON_有効

値が有効な JSON であるかどうかを示す 0 または 1 を返します。 引数が NULL の場合、 NULL を返します。

mysql> JSON_VALID('{"a": 1}')を選択します。
+------------------------+
| JSON_VALID('{"a": 1}') |
+------------------------+
| 1 |
+------------------------+
mysql> JSON_VALID('hello') を選択し、JSON_VALID('"hello"') を選択します。
+---------------------+-----------------------+
| JSON_VALID('hello') | JSON_VALID('"hello"') |
+---------------------+-----------------------+
| 0 | 1 |
+---------------------+-----------------------+

上記はMysqlクエリJSON結果の関連関数の概要の詳細内容です。MySQL json関数の詳細については、123WORDPRESS.COMの他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • MySql ファジークエリ JSON キーワード取得ソリューションの例
  • Mysql クエリの結果セットを JSON データに変換するサンプル コード
  • MySQL で JSON 形式のフィールドをクエリする詳細な説明
  • MySQL json 形式のデータクエリ操作
  • MySQL フルテキスト インデックス、ジョイント インデックス、Like クエリ、JSON クエリのうち、どれが高速ですか?
  • MySQL クエリ フィールド タイプが json の場合の 2 つのクエリ メソッド
  • Python クエリ mysql、json インスタンスを返す
  • mysql5.6 以前のデータベースで json をクエリする方法
  • Mysqlは保存されたJSON文字列内のデータを直接クエリします

<<:  Vue を使用して 2 つのデータ セットの違いを比較する視覚化コンポーネントの詳細な説明

>>:  IdeaでTomcatを起動したときに複数のリスナーが報告される問題を解決する

推薦する

3分でUbuntu 16.04を初期化し、Java、Maven、Docker環境をデプロイする

Fast-Linux プロジェクト アドレス: https://gitee.com/uitc/Fas...

ろうそくを溶かす(水滴)サンプルコードを実現する純粋な CSS

成果を達成する実装のアイデアフィルターのコントラストとぼかしを利用して溶ける効果を実現します。親要素...

Dockerを使用して開発環境を構築する方法を素早く習得します

プラットフォームが成長し続けるにつれて、プロジェクトの研究開発は、開発者向けのさまざまな外部環境、特...

HTMLファイル内の中国語の文字化けとブラウザでの表示の問題

今日も私のページが文字化けしていたので、インターネットで関連する問題を検索しました。この方法はかなり...

MySQL の一般的な問題とアプリケーション スキルの概要

序文MySQL の日常的な開発やメンテナンスでは、パスワードの紛失やテーブルの破損など、避けられない...

CSS calc() の数式に関する詳細な理解

数式 calc() は CSS の関数であり、主に数学演算に使用されます。 calc() を使用する...

HTMLリンクを書くときは、HTTPリクエストを減らすためにサブフォルダに必ずスラッシュを追加してください。

サブフォルダーの末尾にスラッシュがない場合、2 つの HTTP リクエストが生成され、効率に影響しま...

docker compose を使ってワンクリックで分散構成センター Apollo を展開するプロセスの詳細な説明

導入分散について話すときは、分散構成センター、分散ログ、分散リンク トラッキングなどについて考える必...

MySQL ファントムリードとその排除方法の詳細な説明

目次トランザクション分離レベルファントムリーディングとは何ですか?ファントムリードを排除する方法要約...

Ubuntu 16.04 で FTP サーバーを構築するチュートリアル

Ubuntu 16.04 FTP サーバーをビルドするftpをインストールするftp をインストール...

適応型ウェブページを設計および作成する方法

3G の普及により、携帯電話を使ってインターネットにアクセスする人が増えています。モバイル デバイス...

新しい CSS :where および :is 疑似クラス関数とは何ですか?

:is と :where とは何ですか? :is()と:where()は、セレクターを作成するとき...

シェルを使用してMySQLデータバックアップスクリプトを作成する

アイデアそれは実はとても簡単ですシェル スクリプトを記述して、mysql の mysqldump を...

Windows での Apache+Tomcat7 負荷分散構成方法の詳細な説明

準備Windows Server 2008 R2 Enterprise (2.40GH、8GB、64...

MySQL マスタースレーブレプリケーションの遅延の原因と解決策

目次レプリケーション ロジックの簡単な概要:遅延の原因と解決策〇メインデータベースへの頻繁なDMLリ...