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

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

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

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

3回答

1035閲覧

SQLでJOINをしたい

torachi

総合スコア19

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2019/06/06 03:12

編集2019/06/06 04:48

前提・実現したいこと

SQLでJOINしたいです。
JOINする値に、同じものが複数あります。

tableA

ID名前番号
1りんごA
2めろんB
3バナナC
4いちごD

tableB

ID番号産地日付
1A大阪5/8
2A大阪6/10
3B京都6/12
4D奈良6/15
5C滋賀7/8
6B京都7/20

この表を番号でJOINして

ID名前番号産地
1りんごA大阪
2めろんB京都
3バナナC滋賀
4いちごD奈良

という風な表にしたいです。

該当のソースコード

SELECT tableA.* , tableB.産地 FROM table LEFT JOIN tableB ON tableA.番号 = tableB.番号

発生している問題

現在、上記のソースコードでは、SQLがうまく動かず、
値をひとつもとってきません。

補足情報(FW/ツールのバージョンなど)

使用しているのは、レンタルサーバーのPHPMyadminのMysqlです。

バージョン情報: 4.8.4

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

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

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

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

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

Orlofsky

2019/06/06 03:25

同じSQLでもデータベースやそのバージョンによって方言が大きいですから、どのデータベースを使うのかを質問のタグで明示したり、バージョンも明記した方が適切なコメントが付き易いです。
m.ts10806

2019/06/06 03:25

「できますか?」という質問だと「できます」だけの回答になりますがよろしいですか? 自身が何かしら調べて検証して実現できていないのでしたら、その試行錯誤されている状況を具体的に記載してください。
m.ts10806

2019/06/06 03:26

※厳密にはJOINはSQLでするもなので「PHPではできない」が回答ですが
torachi

2019/06/06 04:29

サーバーはレンタルサーバーなのですが、バージョンや、データベースの種類? などは、 知識不足でよくわかりません。 すみません。
m.ts10806

2019/06/06 04:38

PHPタグは外しておいてください。 レンタルサーバーであればおそらくデータベースを操作する管理画面(例えばphpMyAdminなど)があるはずです。phpMyAdminであればMySQLかMariaDBなのは確定ですが。バージョンもその管理画面のトップにあると思います。
sazi

2019/06/06 04:50 編集

追記されたSQLには問題無さそうですけど。 省略しすぎて、問題の箇所まで省略されているのかもしれません。 データに問題があるのかもしれませんし、確認されているのがPHPを介したものであったりしませんか? 再現できる状態の質問にされて下さい。
guest

回答3

0

ベストアンサー

質問内容が理解できていないですが、表1と表2から表3を作成することは可能です。

ご自身の書いた SQL を提示し、テーブル構造を追記することで適切な回答が得られると思います。

投稿2019/06/06 03:18

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

PHPで主キーが複数あるJOINをしたい

まず「主キーが複数ある」自体が謎
またjoinするのはSQL側なので、SQLでできるかどうかは検討するとして
PHPではできない

なお表2は番号に対して産地が1対1で対応するモデルだと思うので
表2自体を正規化すべきです。
そうでないなら表2をdistinctしたサブクエリを表1にjoinしてください

投稿2019/06/06 03:20

yambejp

総合スコア114769

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

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

0

SQL

1SELECT 2 T1.ID 3 , T1.名前 4 , T2.番号 5 , T1.産地 6FROM1 T1 7INNER JOIN2 T2 8ON T1.番号 = T2.番号;

質問に CREATE TABLE 文程度は提示しましょうね。

投稿2019/06/06 03:18

編集2019/06/06 04:39
Orlofsky

総合スコア16415

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

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

sazi

2019/06/06 03:35 編集

やるなら、IDじゃなく番号で結合。
Orlofsky

2019/06/06 04:38

なるほど。変なテーブル定義ですね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問