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

推薦する

Vueバインディングオブジェクトと配列変数を変更した後にレンダリングできない問題の解決策

プロジェクトシナリオ:ページ表示には <ul> タグがあります。リストデータを動的に表示...

Vueコンポーネント間のデータ共有の詳細な説明

目次1. プロジェクト開発において、コンポーネント間の最も一般的な関係は次の 2 つのタイプに分けら...

dockerでPostgreSQLを実行する方法

1. Dockerをインストールします。参考URL: Docker 入門インストールチュートリアル ...

MySQL データベースを最適化する 8 つの方法の詳細な説明 (必読の定番)

導入:インターネット上にはデータベースの最適化に関する情報や方法が数多くありますが、その多くは品質に...

メニューノードのすべての子ノードを再帰的に検索する MySQL メソッド

背景プロジェクトにはメニューノードのすべてのノードをチェックする要件があります。オンラインでチェック...

IE6 で CSS スタイルの div または li の背景のタイリングと境界の破損を解決する方法

IE6 で CSS スタイルの div または li の背景のタイリングや境界の破壊を解決するには、...

シームレスなカルーセル効果を実現するネイティブ js

参考までに、ネイティブjsでカルーセル効果(シームレススクロール)を実現しています。具体的な内容は以...

Centos7 構成 fastdfs および nginx 分散ファイル ストレージ システムの実装プロセス分析

1. libfastcommon-1.0.43 をインストールします。インストール パッケージは h...

今日と昨日の 0:00 タイムスタンプを取得する MySQL の例

以下のように表示されます。昨日: UNIX_TIMESTAMP(CAST(SYSDATE() AS ...

背景画像に CSS3 変換を適用するためのソリューション

CSS 変換は便利ですが、背景画像にはまだ適用されていません。この投稿では、背景画像を回転させたい場...

入力のsize属性とmaxlength属性の違い

最近、プロジェクトで input size 属性と maxlength 属性を使用しました。以前は、...

Linux の grep コマンドと egrep コマンドの詳細な説明

反復/egrep構文: grep [-cinvABC] 'word' ファイル名-c...

MySQL コール初心者が犯しがちな 11 の間違いのまとめ

序文セキュリティ部門からSQLインジェクションやXSS攻撃の脆弱性などに関する警告メールを頻繁に受け...

Tomcat サーバーの応答が遅い場合の解決策

1. 分析的思考1. 機械自身の理由を排除する2. サーバーパフォーマンス分析3. プロジェクト自体...

HTMLチェックボックス説明テキストをクリックして状態を選択/チェック解除します

Web 開発では、チェックボックスは小さく、ユーザーにとって操作があまり便利ではないため、ユーザーが...