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

推薦する

州と市町村の連携を簡単に実現するJavaScript

この記事では、省と市の簡単な連携を実現するためのJavaScriptの具体的なコードを参考までに紹介...

ビジュアルデザインとインタラクションデザインについて

<br />製品設計プロセス全体において、ビジュアルデザインとインタラクションデザインの...

MySQLでBLOBデータを処理する方法

具体的なコードは次のとおりです。 パッケージ epoint.mppdb_01.h3c; java.i...

Zookeeper&Kafka クラスターを構築するための Docker の実装

最近Kafka勉強しています。クラスタの状態をテストする準備をしていたときに、仮想マシンを 3 つ開...

MySQL マルチテーブルクエリ例の詳しい解説 [リンククエリ、サブクエリなど]

この記事では、例を挙げて MySQL のマルチテーブル クエリについて説明します。ご参考までに、詳細...

MySQL 8.0.11 圧縮版のインストールチュートリアル

この記事では、MySQL 8.0.11のインストールチュートリアルを参考までに紹介します。具体的な内...

MySQL は ACID トランザクションをどのように実装しますか?

序文最近、面接中に、MySQL の InnoDB エンジンがどのようにトランザクションを実装している...

HTML印刷関連の操作と実装の詳細な説明

原則的にはwindow.print()メソッドを呼び出すことですが、このメソッドは現在のページ全体を...

HTML入力ドロップダウンメニューを実装する方法

コードをコピーコードは次のとおりです。 <html> <ヘッド> <m...

JavaScriptでページスクロールアニメーションを実装する

目次レイアウトを作成するCSSスタイルを追加するJavaScript で要素を操作する対象要素を取得...

MYSQLはUnionを使用して2つのテーブルのデータを結合し、表示します。

UNION演算子の使用union : 2 つ以上の SELECT ステートメントの結果を 1 つの...

あまり多くのコードを書かずに、ハイパーリンクを使ってシンプルで美しいカスタムチェックボックスを実装できます。

今日ふと、HTML でチェックボックスのスタイルを変更できる範囲が限られていることと、チェックボック...

MySQLデータベーストリガーの詳細な説明

目次1 はじめに2 トリガーの紹介3 トリガーを作成する4 トリガーを表示5. トリガーの削除6 結...

MySQL データベース SELECT クエリ式分析

データ管理の大部分は検索であり、SELECT はその大部分を占めています。 SELECT selec...

CentOS7 での PostgreSQL 11 の詳細なインストールと設定のチュートリアル

1. 公式ウェブサイトアドレス公式サイトではインストールの参考手順が紹介されています。公式サイトを見...