質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

JOIN

これはSQL文のJOINに関するタグです。リレーショナルデータベースシステムの二つ以上のテーブルを結合する際に、この構文が利用されます。

Q&A

解決済

3回答

1163閲覧

MySQLで複数テーブルの値を結合するが重複したデータが生成される

退会済みユーザー

退会済みユーザー

総合スコア0

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

JOIN

これはSQL文のJOINに関するタグです。リレーショナルデータベースシステムの二つ以上のテーブルを結合する際に、この構文が利用されます。

0グッド

1クリップ

投稿2020/01/24 11:01

前提・実現したいこと

複数の元データから必要な項目だけを結合させたテーブルT1をつくりたいと思っています。
ベースになるテーブルT2は、2つのカラムをあわせてユニークとしており、重複はしていません。 たとえばAカラムBカラムとあった場合、 A 1 B 1 とA 1 B 2は別物と判断します。

テーブルT2にleft joinで20個近くのテーブルからデータをビューで結合させ、そのデータをT1にインポートしようと思っています。

しかし、結合させたビューはベースのT2よりレコード数が増え、AカラムBカラムが重複したものが生成されてしまいます。
そこで、select distinctで重複を削除しようとしましたが、重複していないものまで削除されてしまいました(3件)。さらに、重複しているのに消されていないものも1件ありました。
ビューのカラム数は50あります。
T2のレコード数は10700件ほどです。
重複があるレコードの重複数はまちまちで、2つ重複もあれば、15重複しているものまであります。

何か解決策がありますでしょうか?
ビューで結合する段階で間違えているため重複レコードができてしまうのでしょうか。
ここで躓いて先に進めないでいます。
宜しくお願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

テーブルT2にleft joinで20個近くのテーブルからデータをビューで結合させ、そのデータをT1にインポートしようと思っています。

差し支えない限り(テーブル名や列名を仮のものに変更するとか)で確認できるCREATE TABLE, 各テーブルに存在するデータの INSERT を含めて質問にMarkdown の[コード]で追記しては?

投稿2020/01/24 12:49

Orlofsky

総合スコア16415

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/01/31 01:28

Orlofskyさま ひとつずつ検証したところ、問題がわかりました。 コメントいただきありがとうございました。
guest

0

ベストアンサー

ビューで結合する段階で間違えているため重複レコードができてしまうのでしょうか。

その可能性が一番高いです。

テーブルT2にleft joinで20個近くのテーブルからデータをビューで結合させ

地道に、一つずつ結合を追加して変化の起きる箇所を確認して下さい。

投稿2020/01/24 11:33

sazi

総合スコア25173

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/01/31 01:29

saziさま 一つずつ結合をさせて、問題がわかりました。 元々ファイルメーカーになれているので、同じ感覚で結合させていたために、問題が起きていました。 ありがとうございました。
guest

0

結合条件が適当すぎるのでしょう。

m個のデータとn個のデータのテーブル同士を結合すると
最大m*n個のレコードが参照されます

投稿2020/01/24 11:06

yambejp

総合スコア114777

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/01/31 01:31

yambejpさま コメントありがとうございました。 おっしゃるとおりでした。 MySQLの結合条件は難しいです><
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問