Mysql はクエリ結果セットを JSON データに変換します 序文 学生テーブル 学生スコアテーブル 1 人の学生の各科目のスコアをクエリします (オブジェクト JSON 文字列に変換し、カンマで連結します) 1 人の学生の各科目のスコアを配列 JSON 文字列に変換します 配列文字列を値として使用し、キーを設定します 2 つのテーブルの結合クエリ (最終 SQL、各学生の各科目のスコア) 最終結果 序文
学生テーブル 存在しない場合はテーブルを作成します `student`( `id` INT UNSIGNED AUTO_INCREMENT、 `name` VARCHAR(100) NOT NULL 主キー ( `id` ) )ENGINE=InnoDB デフォルト文字セット=utf8; 学生にINSERT INTO( id, name ) VALUES ( 1, '张三' ); 学生に挿入(ID、名前)VALUES(2、'Li Si'); 学生成績証明書 存在しない場合はテーブルを作成 `score`( `id` INT UNSIGNED AUTO_INCREMENT、 `name` VARCHAR(100) NOT NULL `student_id` INT(100) NOT NULL, `スコア` VARCHAR(100) NOT NULL 主キー ( `id` ) )ENGINE=InnoDB デフォルト文字セット=utf8; スコアに INSERT INTO します( id, name, student_id, score) VALUES ( 1, '数学', 1, '95.5' ); スコアにINSERT INTO( id, name, student_id, score) VALUES ( 2, 'Chinese', 1, '99.5' ); スコアにINSERT INTO( id, name, student_id, score) VALUES ( 3, '数学', 2, '95.5' ); スコアにINSERT INTO( id, name, student_id, score) VALUES ( 4, 'Chinese', 2, '88' ); 1 人の生徒の各科目のスコアを照会します (オブジェクト JSON 文字列に変換し、カンマで連結します) GROUP_CONCAT(JSON_OBJECT( を選択) 'id'、id、'name'、name、'student_id'、student_id、'score'、score)) をスコアとして FROM score に格納します。ここで、student_id は 1 です。 ## クエリ結果## {"id": 1, "name": "数学", "student_id": 1, "score": "95.5"},{"id": 2, "name": "中国語", "student_id": 1, "score": "99.5"} 1人の生徒の成績を配列JSON文字列に変換する SELECT CONCAT('[', GROUP_CONCAT(JSON_OBJECT( 'id',id,'name',name,'student_id',student_id, 'score', score)), ']') を scores FROM score として指定します。ここで、student_id は 1 です。 ## クエリ結果## [{"id": 1, "name": "数学", "student_id": 1, "score": "95.5"},{"id": 2, "name": "中国語", "student_id": 1, "score": "99.5"}] 配列文字列を値として使用し、キーを設定します SELECT CONCAT('{"scoreData":[', GROUP_CONCAT(JSON_OBJECT( 'id',id,'name',name,'student_id',student_id, 'score', score)), ']}') を scores FROM score として指定します。ここで、student_id は 1 です。 ## クエリ結果## {"scoreData": [{"id": 1, "name": "Mathematics", "student_id": 1, "score": "95.5"},{"id": 2, "name": "Chinese", "student_id": 1, "score": "99.5"}]} 2 つのテーブルの結合クエリ (最終 SQL、各科目の各生徒の成績) SELECT ID、名前、 (SELECT CONCAT('[', GROUP_CONCAT(JSON_OBJECT( 'id',id,'name',name,'student_id',student_id, 'score', score)), ']') をスコアとして FROM score WHERE student_id = stu.id) をスコアとして 学生から ## [{"id": 1, "name": "数学", "student_id": 1, "score": "95.5"},{"id": 2, "name": "中国語", "student_id": 1, "score": "99.5"}] 最終結果
これで、MySQL クエリ結果セットを JSON データに変換する方法についての説明は終わりです。MySQL 結果セットを JSON データに変換する方法についてさらに詳しく知りたい場合は、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: Vue でインデックスをキー属性値として使用することが推奨されないのはなぜですか?
>>: Dockerはプライベートライブラリイメージを完全に削除します
問題コードuseEffectによって発生したクロージャの問題コードを見てみましょう 定数 btn =...
今日はMySQLのインストール方法を学びましたが、その過程でいくつか問題が発生しました。関連記事をい...
この記事では、ボタン切り替え画像を実現するためのVueの具体的なコードを例として紹介します。具体的な...
目次tinymce、tinymce ts、tinymce-vue 宣言ファイルをインストールするパッ...
目次必要:アイデア:レッスン:テキストを共有する:要約する必要:インターフェイスからサブメニュー デ...
この記事は主にMySQLデータ移行方法とツールの分析を紹介します。サンプルコードを通じて詳細に紹介さ...
注意: 計画、設計、開発のいずれの場合でも、これらの間違いは避けなければなりません。 1. ナビゲー...
まずmysqlを削除します: sudo apt-get remove mysql-*残ったデータをク...
最も単純な hello world 出力イメージを作成することは最も簡単なスタートですが、実行中のコ...
1. はじめにtelnet コマンドは、リモート ホストにログインするために使用されます。これは、T...
目次1. データベース論理バックアップとはどのようなバックアップですか? 2. よく使われる論理バッ...
コンピュータ サイエンスで最も一般的に使用され、議論されているデータ構造の 1 つは、二分探索木です...
序文ヒストグラムは、RDBMS によって提供される基本的な統計情報です。最も一般的に使用されるのは、...
この間、私は docker を勉強していたのですが、nginx をデプロイするときに行き詰まりました...
目次1. 手順2. 修飾語3. .sync 修飾子4. まとめ1. 手順指示とは命令です。文字通りの...