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 を応援していただければ幸いです。間違いや不備な点がありましたら、遠慮なくご指摘ください。 以下もご興味があるかもしれません:
|
この記事では、カラービューアを実装するためのJavaScriptの具体的なコードを参考までに紹介しま...
ソースコード(一部のクラスは削除されています):コードをコピーコードは次のとおりです。 <テー...
目次序文原因を発見するカスタムフィルタリングルール要約する序文インターネットの急速な発展に伴い、情報...
目次mysql 権限制御権限システムテーブル変更後にMySQLの権限を有効にする方法権限の付与と取り...
目次圧縮ファイルをダウンロードするアドレス: https://dev.mysql.com/downl...
この記事では、JSオブジェクト指向タイピングゲームの具体的なコードを参考までに紹介します。具体的な内...
ElementUIは、参考のためにテーブルツリーリストの読み込みチュートリアルを実装しています。具体...
1. スタートアップメニューでは、カーソルを最初の行に移動します - eを押します 2. UTF-8...
目次序文最適化変数の抽出二次包装 el-tag コンポーネント使用要約する序文バックエンドシステムの...
この記事はMySQL 8.0に基づいていますこの記事では、日付と時刻の操作のための MySQL 関数...
httpリターンコードリスト(以下は概要です)詳細な中国語の説明についてはここをクリックしてくださ...
目次1. プロセスとスレッドの概念2. プロセス管理とは何ですか? 3. プロセス管理の役割4. L...
1. まず、nginxの位置情報に関する関連知識を確認しましょう1) 位置マッチング手順: ~ #波...
序文インデックスを追加した場合と追加しなかった場合の違いを反映するには、数百万のデータを使用する必要...
MySQL 運用上の問題点を記録します。ビジネスシナリオと問題の説明外部インターフェースをリクエスト...