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の書き換えモジュールの詳細な説明

推薦する

アコーディオン効果を実現するネイティブ js

実際のWebページ開発でも、アコーディオンは頻繁に登場します。簡単なアコーディオンを作ったのですが、...

CSS でフロートとマージンを混合するサンプルコード

最近の勉強で、GitHub でレイアウトの練習をいくつか見つけたのですが、レイアウトにまったく慣れて...

Linux C バックグラウンドサービスプログラムの単一プロセス制御の実装

導入通常、バックグラウンド サーバー プログラムには 1 つのプロセスのみが必要ですが、単一のプロセ...

DockerはGitを使用してJenkinsのリリースとテストプロジェクトの詳細なプロセスを実装します

目次1. Dockerをインストールする2. カスタムネットワークアドレスを作成する3. Docke...

HTML のオートコンプリートを無効にして履歴を表示しないようにする

入力ボックスには、コンテンツを入力するときに常に入力履歴が表示されます。これを無効にする現在の方法は...

LinuxでHomebrewを使用する正しい方法

多くの人が Linux Homebrew を使用しています。これをより良く使用するための 3 つのヒ...

MySql で正規表現クエリを使用する方法

正規表現は、特定のパターンに一致するテキストを検索および置換するためによく使用されます。たとえば、テ...

Linux システムでのスケジュールされたタスクの紹介

目次1. 計画タスクをカスタマイズする2. 時間を同期する3. 練習する4. セキュリティの問題1....

Node.js で簡単なクローラーケースを作成するチュートリアル

準備まず、nodejs をダウンロードする必要がありますが、これは問題ないはずです。原文はwebst...

CSS の clip-path プロパティの使用方法の詳細な説明

クリップパスの使用ポリゴン値は複数の座標点で構成されます。最初の値は x 方向、2 番目の値は y ...

docker を使用して crownblog プロジェクトを Alibaba Cloud にデプロイする方法

フロントエンドプロジェクトのパッケージ化.env.productionを見つけて、自分のIPまたはド...

CentOS 7 に mysql5.7 の解凍バージョンをインストールするチュートリアル

1. mysqlの圧縮パッケージを/usr/localフォルダに解凍し、名前をmysqlに変更します...

ウェブページ内でウェブテーブルやdivレイヤーが引き伸ばされる問題の解決策

<br />Web ページをデザインするときには、いつも不快なことに遭遇します。最も一般...

Ubuntu 16.04 に nvidia ドライバー + CUDA + cuDNN をインストールする詳細なチュートリアル

準備1. GPUがCUDAをサポートしているかどうかを確認するlspci | grep -i nvi...

HTML の類似タグと属性の違いの詳細な説明

【1】<i></i>タグと<em></em>タグ同じ...