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 インストール詳細チュートリアル (画像とテキスト)

推薦する

jar パッケージを Docker コンテナに変換する方法

jar パッケージを Docker コンテナに変換する方法1.まずJavaイメージをダウンロードする...

Google Chromeの自動入力問題に対する完璧な解決策

Google Chrome では、ログインに成功すると、パスワードを記憶するかどうかを尋ねるメッセー...

Vueの監視プロパティの詳細

目次1.watchは一般的なデータ(数値、文字列、ブール値)の変更を監視します。 1. 数値2. 文...

Element UI で自動サイズ調整テキストエリアの高さを設定する方法

Element UIのtextarea input自動サイズに設定すると、テキストボックスのデフォル...

ウェブページ上の小さなスペースに大きな画像を配置する方法

出典: www.bamagazine.comウェブページのバナー、ニュースの見出しの周りのスペース、...

Windows 10 で Ubuntu 20.04 LTS をアップデートする方法

2020 年 4 月 23 日、本日、Windows 上の Ubuntu 20.04 では、Ubun...

ユーザーがフォームを繰り返し送信するのを防ぐ方法の概要

重複したフォーム送信は、マルチユーザー Web アプリケーションで最も一般的で厄介な問題です。重複送...

Vueはショッピングカート決済機能をシミュレートします

この記事では、ショッピングカート決済機能を実現するためのVueの具体的なコードを例として紹介します。...

ローカルサーバーを構築するためのwebpack-dev-serverの実装

目次序文webpack-deb サーバーwebpack-dev-server 起動エラー解決策1解決...

Vueコンポーネントの基本のまとめ

コンポーネントの基本1 コンポーネントの再利用コンポーネントは再利用可能な Vue インスタンスです...

Docker で Let's Encrypt から永久無料 SSL 証明書を取得する方法

1. 原因公式の cerbot は面倒すぎます。野生の成長よりもさらに悪い acme.sh の使用は...

40以上の美しいWebフォームデザイン例

Web フォームは、訪問者と Web サイト所有者間の主要なコミュニケーション チャネルです。フィー...

nginxとIISで使用できるSSL証明書を作成する

目次SSL証明書の作成1. 秘密鍵を生成する2. 証明書要求ファイルを生成する3. CRT証明書ファ...

MySQL 5.5.56 インストール不要版の設定方法

MySQL 5.5.56無料インストール版の設定方法をテキストコードで詳しく説明します。具体的な内容...

RocketMQ の Docker インストールとインストール中に発生した問題の解決策

目次rocketmqイメージを取得する名前rvを作成する単一のブローカーノードを作成するrocket...