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

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

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

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

Q&A

解決済

2回答

5620閲覧

同じテーブルを複数回joinしてデータを取得したい

kenji267

総合スコア50

MySQL

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

0グッド

1クリップ

投稿2017/12/31 06:20

###前提・実現したいこと
要は同じテーブルを複数回joinしたいだけなんですが、なぜかエラーになります。
文法エラーみたいですが、どこかわかりません。結構時間かけています。
稚拙ですが、自分以外の人の目で見たらすぐにわかると思い質問を投げさせていただきます。
宜しくお願いします。

###発生している問題・エラーメッセージ

Error Code: 1064. You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'left join hanyo as h2 on c.birthplace = h2.subcode where h2.code = 'A02' and c.' at line 3 0.047 sec

###該当のソースコード

sql

1select * from customer as c 2 left join hanyo as h1 on c.sex = h1.subcode where h1.code = 'A01' and c.id=1 3 left join hanyo as h2 on c.birthplace = h2.subcode where h2.code = 'A02' and c.id=1

###試したこと
色々リサーチし、順序変えたりして試しましたがどこが文法的におかしいのか見当がつきません。

###補足情報(言語/FW/ツール等のバージョンなど)
より詳細な情報
テーブル
create table customer (
id int not null auto_increment primary key,
name varchar(50),
sex tinyint(1),
birthplace tinyint(2),
position tinyint(2)
);
create table hanyo (
code varchar(3),
subcode varchar(3),
name text
);
データ
insert into customer (name,sex,birthplace,position) values
('山田太郎',1,2,2),
('町村洋子',2,2,1)

insert into hanyo (code,subcode,name) values
('A01',1,'男'),
('A01',2,'女'),
('A02',1,'マネージャ'),
('A02',2,'担当')

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

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

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

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

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

guest

回答2

0

文法的な間違いは、where が複数書かれていることです。
とりあえず、where を AND に変えるだけで動くと思います。

それとは別に根本的な問題があります。
汎用的な属性テーブルを使っていることです。
SQLアンチパターンで言う「EAV (エンティティ・アトリビュート・バリュー)」に該当します。
このやり方はリレーショナルデータベースとの相性が極めて悪いのです。
詳しくはググってくだされたし。

投稿2017/12/31 07:03

hihijiji

総合スコア4150

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

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

kenji267

2017/12/31 07:33

ありがとうございます。whereを複数回書いていました…、andにすれば動きました。 追記のアドバイス確認しました。効率のよいやり方と思ったのですがとんでもない勘違いでした。
guest

0

ベストアンサー

文法的にjoin onの次は連結条件であってwhere句ではないです。
joinは表の連結、whereは行の抽出をあくまで担当しています。

多分こう書きたいのではないかと推測します。

sql

1select * from customer as c 2 left join hanyo as h1 on c.sex = h1.subcode and h1.code = 'A01' 3 left join hanyo as h2 on c.birthplace = h2.subcode and h2.code = 'A02' 4where c.id=1

擬似的にh1.codeに対してwhere句をかけているように見えますが意味は厳密には違います。

sql

1select * from customer as c 2 left join hanyo as h1 on c.sex = h1.subcode 3 left join hanyo as h2 on c.birthplace = h2.subcode 4where c.id=1 5 and h1.code = 'A01' 6 and h2.code = 'A02'

投稿2017/12/31 07:18

sousuke

総合スコア3828

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

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

kenji267

2017/12/31 07:38

whereの使い方をわかっていませんでした。 書きたいことはおっしゃる通りです。 違いはこれを機会に確認していきたいと思います。 たすかりました、ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問