MySQL で複数のフィールドを連結する詳細な例

MySQL で複数のフィールドを連結する詳細な例

MySQL クエリ結果の行フィールドの結合は、次の 2 つの関数を使用して実装できます。

1. concat関数

mysql> テストから concat('1','2','3') を選択します。
+---------------------+
| 連結('1','2','3') |
+---------------------+
| 123 |
+---------------------+

接続文字列に NULL が含まれている場合、返される結果は NULL になります。

mysql> テストから concat('1','2',NULL,'3') を選択します。
+--------------------------+
| 連結('1','2',NULL,'3') |
+--------------------------+
| NULL |
+--------------------------+

2. concat_ws関数

concat(separator,str1,str2,...) はセパレータによる連結を表し、concat() の特殊な形式です。最初のパラメータは他のパラメータの区切り文字です。区切り文字は、連結される 2 つの文字列の間に配置されます。区切り文字には文字列または他のパラメータを使用できます。

mysql> テストから concat_ws(':','1','2','3') を選択します。
+----------------------------+
| 連結ws(':','1','2','3') |
+----------------------------+
| 1:2:3 |
+----------------------------+

区切り文字が NULL の場合、戻り値は NULL になります。

mysql> テストから concat_ws(NULL,'1','2','3') を選択します。 
+-----------------------------+
| 連結ws(NULL,'1','2','3') |
+-----------------------------+
| NULL | 
+-----------------------------+

パラメータに NULL が含まれている場合は無視されます。

mysql> テストから concat_ws(':','1','2',NULL,NULL,NULL,'3') を選択します。
+------------------------------------------+
| 連結ws(':','1','2',NULL,NULL,NULL,'3') |
+------------------------------------------+
| 1:2:3 |
+------------------------------------------+

NULL を判断して他の値に置き換えることができます。

mysql> 銀行制限 1 から concat_ws(':','1','2',ifNULL(NULL,'0'),'3') を選択します。 
+---------------------------------------------+
| concat_ws(':','1','2',ifNULL(NULL,'0'),'3') |
+---------------------------------------------+
| 1:2:0:3 | 
+---------------------------------------------+

補足:補足:MySQLでグループ化する場合、フィールドの値を連結する

t_dog テーブル

t_ワクチン表

t_dog_vaccine テーブル

問題の説明

dog_vaccine 内の各犬に対応するワクチンを照会する必要があります。犬とワクチンの間には多対多の関係があるため、1 匹の犬が複数のワクチンに対応する可能性がありますが、文字列を使用してこれらの複数のワクチンを 1 つに連結し、Java エンティティ クラスにマップしたいと考えています。

段階的に解決する

2 つの左結合クエリを使用して、3 つのテーブル t_dog、t_vaccine、t_dog_vaccine を関連付けました。

IDとしてdv.idを選択し、
 d.dog_name を dogName、v.vaccine_name として 
 から 
 t_犬_ワクチン dv
  t_dog d を dv.dog_id = d.id に左結合します
  t_vaccine v を dv.vaccine_id = v.id に左結合します

これは犬とワクチンが一致していますが、犬ごとに複数のレコードがあり、犬の名前と複数のvaccin_namesの値を文字列に結合したデータのみが必要です。考えてみたところ、ふとgroup byを思いつきました。

IDとしてdv.idを選択し、
 d.dog_name を dogName、v.vaccine_name として 
 から 
 t_犬_ワクチン dv
  t_dog d を dv.dog_id = d.id に左結合します
  t_vaccine v を dv.vaccine_id = v.id に左結合します 
  dogName でグループ化

group by を使用すると、当然期待した結果にはなりません。dogName は 1 つしかありませんが、それに対応するワクチンも 1 つしかありません。ワクチン名を複数にしたいのですが、どうすればよいでしょうか。 文字列連結を行える関数はありますか?うーん、わかりました、group_concat。 。 。

IDとしてdv.idを選択し、
 d.dog_name を dogName として、
 group_concat(v.vaccine_name) を dogVaccineName として  
 から 
 t_犬_ワクチン dv
  t_dog d を dv.dog_id = d.id に左結合します
  t_vaccine v を dv.vaccine_id = v.id に左結合します 
 d.dog_name でグループ化

これにより、望んでいた効果が達成されました。

group_concat の使用法

デフォルトの使用法

t_vaccine から dogVaccineName として group_concat(vaccine_name) を選択します。id は (t_dog_vaccine から vaccine_id を選択します。dog_id = 1)

group_concat のデフォルトの区切り文字は ',' です。この区切り文字を変更したい場合は、変更できます。

REPLACE(group_concat(vaccine_name),',','変更したい区切り文字をここに入力してください')

たとえば、デフォルトを次のように変更します。

t_vaccine から dogVaccineName として REPLACE(group_concat(vaccine_name),',',';') を選択します。ID は (t_dog_vaccine から vaccine_id を選択します。dog_id = 1)

上記は私の個人的な経験です。参考になれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。間違いや不備な点がありましたら、遠慮なくご指摘ください。

以下もご興味があるかもしれません:
  • MySQLクエリ時にフィールドにデフォルト値を割り当てる方法
  • MySQL コマンドラインでテーブルにフィールドを追加します (フィールド名、空かどうか、デフォルト値)
  • MySQL テーブル フィールドのデフォルト値の設定 (グラフィック チュートリアルと詳細に注意)
  • MySQL 8.0の新機能、隠しフィールドの詳細な説明
  • MySQLのどのフィールドがインデックスに適しているかについての簡単な説明
  • mysql 更新ケース更新フィールド値が固定されていない操作
  • MySQLでレコードを変更する場合、更新操作フィールド = フィールド + 文字列
  • MySQL で単一のフィールド内の複数の値を分割および結合する方法
  • 複数のフィールドを変更するためのMysql更新の構文の詳細な分析
  • MySQLフィールドのデフォルト値を設定する方法

<<:  css n番目から始まるすべての要素を取得する

>>:  Nginxの書き換えモジュールの詳細な説明

推薦する

Vueは開始時間と終了時間の範囲クエリを実装します

この記事では、Vueで開始時間と終了時間の範囲を照会する方法を参考までに紹介します。具体的な内容は次...

Xshellの一般的な問題と関連する設定の詳細な説明

この記事では、Xshell と関連する構成の一般的な問題について説明します。この記事の構成は、主に ...

CSS 疑似要素を使用して複数の連続する要素のスタイルを制御する方法

CSS 疑似要素を使用して要素を制御する場合、一部の要素のスタイルを変更する必要があることがよくあり...

MySQLの数値型自動増分における落とし穴

テーブル構造を設計する場合、数値型は最も一般的な型の 1 つですが、数値型をうまく使用するのは想像す...

HTML テーブルタグチュートリアル (12): 境界線スタイル属性 FRAME

FRAME プロパティを使用して、表の境界線のスタイル タイプを制御します。基本的な構文<T...

Dockerにおけるコンテナとイメージの違いについてお話ししましょう

鏡とは何ですか?イメージは、複数のイメージ レイヤー (UnionFS および AUFS ファイル ...

JavaScriptを使って動的にテーブルを生成するケースの詳しい説明

目次序文実装のアイデア実装コード成果を達成する序文これは、テーブルを動的に追加する例です。[追加] ...

自作メニューをクリックする効果を実現するJavaScript

この記事では、自作メニューをクリックする効果を実現するためのJavaScriptの具体的なコードを参...

RabbitMQ の Docker インストールと設定手順

目次単一マシンの展開オンラインプルミラーを見るRabbitMQを作成して実行するMQコンテナを正常に...

MySQL 5.7 スレーブノードからマルチスレッド マスター スレーブ レプリケーションを構成する方法の詳細な説明

序文MySQL は MySQL 5.6 からマルチスレッド レプリケーションをサポートしていますが、...

MySQL インストール プロンプト「詳細なヘルプについては NET HELPMSG 3534 と入力してください」の解決方法

今日、MySQL をインストールすると次のエラー メッセージが表示されます。 かなり長い時間ネットで...

Nginx で https をアップグレードする方法

購入証明書Alibaba CloudのCloud Shield証明書サービスから購入できます。証明書...

Tomcat10 Catalinaのログの文字化けの問題を解決する

実行環境、Idea2020バージョン、Tomcat10、実行時にTomcat CatalinaLog...

MySQL 5.7.13 のインストールと設定方法のグラフィック チュートリアル (win10 64 ビット)

この記事では、参考までにMySQL 5.7.13 winx64のインストールと設定方法のグラフィック...

MySQL 8.0.15 のインストールと設定のグラフィックチュートリアル

この記事ではMySQL 8.0.15のインストールと設定方法を参考までに記録します。具体的な内容は以...