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 を応援していただければ幸いです。間違いや不備な点がありましたら、遠慮なくご指摘ください。 以下もご興味があるかもしれません:
|
この記事では、Vueで開始時間と終了時間の範囲を照会する方法を参考までに紹介します。具体的な内容は次...
この記事では、Xshell と関連する構成の一般的な問題について説明します。この記事の構成は、主に ...
CSS 疑似要素を使用して要素を制御する場合、一部の要素のスタイルを変更する必要があることがよくあり...
テーブル構造を設計する場合、数値型は最も一般的な型の 1 つですが、数値型をうまく使用するのは想像す...
FRAME プロパティを使用して、表の境界線のスタイル タイプを制御します。基本的な構文<T...
鏡とは何ですか?イメージは、複数のイメージ レイヤー (UnionFS および AUFS ファイル ...
目次序文実装のアイデア実装コード成果を達成する序文これは、テーブルを動的に追加する例です。[追加] ...
この記事では、自作メニューをクリックする効果を実現するためのJavaScriptの具体的なコードを参...
目次単一マシンの展開オンラインプルミラーを見るRabbitMQを作成して実行するMQコンテナを正常に...
序文MySQL は MySQL 5.6 からマルチスレッド レプリケーションをサポートしていますが、...
今日、MySQL をインストールすると次のエラー メッセージが表示されます。 かなり長い時間ネットで...
購入証明書Alibaba CloudのCloud Shield証明書サービスから購入できます。証明書...
実行環境、Idea2020バージョン、Tomcat10、実行時にTomcat CatalinaLog...
この記事では、参考までにMySQL 5.7.13 winx64のインストールと設定方法のグラフィック...
この記事ではMySQL 8.0.15のインストールと設定方法を参考までに記録します。具体的な内容は以...