MySQL での GROUP_CONCAT の使用例の分析

MySQL での GROUP_CONCAT の使用例の分析

この記事では、例を使用して、MySQL で GROUP_CONCAT を使用する方法について説明します。ご参考までに、詳細は以下の通りです。

現在、次の構造を持つ 3 つのテーブルがあります。

テーブルを分類:

テーブル `cate` を作成します (
 `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT 'id',
 `name` char(20) DEFAULT '' COMMENT 'カテゴリ名',
 主キー (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8 COMMENT='記事カテゴリテーブル';

記事表:

テーブル「記事」を作成します(
 `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT 'id',
 `title` varchar(50) デフォルト ''
 `cate_id` int(11) NOT NULL DEFAULT '0' COMMENT 'カテゴリID',
 主キー (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8 COMMENT='Article table';

article_extendテーブル:

テーブル `article_extend` を作成します (
 `id` int(10) 符号なし NOT NULL AUTO_INCREMENT,
 `article_id` int(10) unsigned DEFAULT '0' COMMENT '記事ID',
 `name` varchar(255) DEFAULT '' COMMENT 'オーディオ、画像など',
 主キー (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COMMENT='添付ファイル テーブル';

3 つの表のデータは次のとおりです。

テーブルを分類:

記事表:

article_extendテーブル:

ここで問題が発生します。テーブル接続を介してクエリを実行し、記事 ID 1 の記事データを照会して、記事のタイトル、記事のカテゴリ、記事名を表示します。

選択
	a.id AS 援助、
	a.title は atitle として、
	c. NAME AS cname、
	ae.NAME AS aname
から
	記事として
左結合 cate AS c ON a.cate_id = c.id
article_extend を ae として LEFT JOIN し、 a.id = ae.article_id を ON します。
どこ
	1. 文字列を1行に並べます。

結果は次の通りで、2 つのデータが表示されます。

今、私は 1 つの結果、つまり名前フィールドだけを結合したいのですが、どうすればいいでしょうか?

これは GROUP_CONCAT でのみ可能です:

選択
	a.id AS 援助、
	a.title は atitle として、
	c. NAME AS cname、
	GROUP_CONCAT(ae.NAME SEPARATOR '-') AS aname
から
	記事として
左結合 cate AS c ON a.cate_id = c.id
article_extend を ae として LEFT JOIN し、 a.id = ae.article_id を ON します。
どこ
	1. 文字列を1行に並べます。

結果は次のとおりです。

さて、記事 ID で 1 つずつ検索するのではなく、すべてを取得したいのですが、複数の記事名を結合する必要がある場合、どうすればよいでしょうか。

選択
	a.id AS 援助、
	a.title は atitle として、
	c. NAME AS cname、
	ae.allname
から
	記事として
左結合(
	選択
		ae.記事ID、
		GROUP_CONCAT(ae.NAME) AS allname
	から
		記事を拡張する AS ae
	グループ化
		ae.記事ID
) AS ae ON a.id = ae.article_id
cate を c として LEFT JOIN し、 a.cate_id = c.id とします。

結果は次のとおりです。

MySQL 関連のコンテンツに興味のある読者は、このサイトの次のトピックをチェックしてください: 「MySQL クエリ スキル」、「MySQL 共通関数の概要」、「MySQL ログ操作スキル」、「MySQL トランザクション操作スキルの概要」、「MySQL ストアド プロシージャ スキル」、および「MySQL データベース ロック関連スキルの概要」

この記事が皆様のMySQLデータベース設計に役立つことを願っています。

以下もご興味があるかもしれません:
  • Python 3 の文字列 (一重引用符、二重引用符、三重引用符) と文字列と数値間の演算
  • Mysql で group_concat の長さ制限を変更する方法
  • MySQL の連結で複数の一重引用符と三重引用符を使用する際の問題

<<:  Linux MySQL ルートパスワードを忘れた場合の解決方法

>>:  VMware15 の Deepin インストール詳細チュートリアル (画像とテキスト)

推薦する

MySQL データベースのインデックス順序の詳細な説明

目次事件の原因解剖学ファイルの並べ替えファイルのソートが非常に遅いのですが、他に解決策はありますか?...

VMware Workstation 14 Pro のインストールとアクティベーションのグラフィック チュートリアル

この記事では、VMware Workstation 14 Proのインストールとアクティベーションに...

Linux で txt を mysql にインポートする方法

序文昨日、小さなプロジェクトを書いていたときに、txt ドキュメントのデータを mysql データベ...

TypeScript の Enum が問題となる理由

目次どうしたの?いつ使うか列挙の数を制御するビット値コントロールインデックス非数値列挙結論はType...

GoのDockerデプロイメント用の基本イメージ2つの実装

1. golang:最新のベースイメージ mkdir gotest タッチメイン.go Docker...

Linux seqコマンドの使い方

1. コマンドの紹介seq (シーケンス) コマンドは、指定されたステップ サイズに従って、開始番号...

CSS スタイルで一般的なグラフィック効果を示すサンプルコード

一般的な基本グラフィックと私が遭遇するいくつかの小さなアイコンについて簡単に説明します。以下は CS...

Linux ファイルディレクトリ管理コマンドの概要

タッチコマンドこれには 2 つの機能があります。1 つは、既存のファイルの時間タグを現在のシステム時...

CSS3 変換遷移ジッター問題の解決

transform: scale(); スケーリングするとIEブラウザでジッターが発生します変換スケ...

MySQL 5.7 MGR シングルマスター決定マスターノード方式の詳細説明

当銀行のMGRは年末に開始されます。公式文書を読んだり、毎日テストを受けたりしなければなりません。毎...

CSS3は小さな矢印のさまざまなグラフィック効果を実現します

CSS を使ってさまざまなグラフィックを実現できるのは素晴らしいことです。画像を切り取る必要はなく、...

Linux コンパイル最適化で習得しなければならないいくつかの姿勢のまとめ

01. コンパイルオプションとカーネルコンパイルLinux カーネル (英語: linux kern...

Win10 + Ubuntu 16.04 デュアルシステム 完璧なインストールチュートリアル [詳細]

必ずデータをバックアップすることを忘れないでください。データは貴重なものです! ! !コンピュータモ...

MySQLのinnodb_data_file_pathパラメータを変更する際の注意事項

序文innodb_data_file_path は、innodb テーブルスペース ファイルを指定す...