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

推薦する

初心者向けウェブサイト構築チュートリアル: 10 日間でウェブサイトの構築方法を学ぶ

10 日間のチュートリアルでは、最も理解しやすい言語を使用し、最も基本的なことから始めて、誰もが W...

Linux でリモート サーバー ファイルの状態を表示する方法

以下のように表示されます。 test コマンドはファイルが存在するかどうかを判断します。 ssh u...

WeChatアプレットは写真の撮影とアルバムからの写真の選択を実現します

この記事では、WeChatアプレットで写真を撮ったり、アルバムから写真を選択したりするための具体的な...

html2canvasで画像が正常にキャプチャできない時の解決方法

質問まず、私が遭遇した問題についてお話しします。まず、そういった需要があるわけです。フロントエンドは...

単一の MySQL テーブルで数千万のデータを処理するアイデアを共有する

目次プロジェクトの背景改善案データ特性を観察するマルチプロセスアイデアの要約データ処理スキルプロジェ...

デザインにおいて無視できないインタラクティブデザインにおける製品状態の分析

製品デザインのプロセスにおいて、デザイナーは常に写真を非常に美しくすることを好みます。仮想ページのコ...

iframe でページを開く方法

解決:リンクのターゲット属性値をターゲット フレームワーク名と同じに設定するだけです。具体的な手順:...

Vueは単一ファイルコンポーネントの完全なプロセス記録を実装します

目次序文単一ファイルコンポーネント基本概念シンプルなローダーコンポーネントコンテンツの解析コンポーネ...

webpackでCSSを分割・圧縮し、リンクでインポートする手順

まずコードファイルの構造を見てみましょう。エントリファイル (index1.js) の内容: ...

XHTMLにおけるH1タグの位置について

最近、H1 については多くの議論が行われていますが (記事のコンテンツ ページ内)、おおよそ 2 つ...

ウェブページのフッターで注意すべきことのまとめ

たくさんのリンクおそらく、このようなサイトをたくさん見たことがあるでしょう。ページの下部に 50 個...

Centos7 システムでの python2 と python3 の共存

最初のステップは、Python のバージョン番号とインストール パスを確認することです。 上記のビュ...

MySQL での find_in_set() 関数の使用に関する詳細な説明

まず、例を見てみましょう。記事テーブルにはタイプフィールドがあり、1 見出し、2 おすすめ、3 ホッ...

Linuxはnode.jsを完全に削除し、yumコマンドで再インストールします。

最初のステップ組み込みのパッケージ管理機能で一度削除する yum 削除 nodejs npm -y ...