人力検索はてな
モバイル版を表示しています。PC版はこちら
i-mobile

MySQL5の複数ジョイントの質問です。
以下の3つのテーブルをジョイントし、temp_arrayという配列を作りたいのですがSQL文はどのように書けばいいでしょうか?
log_tblのi_idとu_idは、item_tblとuser_tblに存在するはずですが、万が一にもデータが欠けていた場合nullを挿入したいと思います。。
よろしくお願いしますm(_ _)m
また、作りたい配列は文字数の都合でコメントに記しました。

テーブル名:log_tbl(pkey t_id)
t_id, i_id, u_id
1, 203, 45
2, 12, 24
3, 47, 3
4, 3, 45
5, 12, 24
6, 47, 3
7, 14, 13
.....

テーブル名:item_tbl(pkey i_id)
i_id, i_name
1, fff
2, kkk
12, bbbbb
13, mmm
14, ccccc
47, hhhhh
203, sssss
....

テーブル名:user_tbl(pkey u_id)
u_id, u_name
1, taro
2, yamada
3, sato
24, kawakita
45, hoge
.....

●質問者: seadwell
●カテゴリ:ウェブ制作
✍キーワード:24 FFF hoge KKK MMM
○ 状態 :終了
└ 回答数 : 1/1件

▽最新の回答へ

1 ● うぃんど
●60ポイント ベストアンサー

SQLとしては下記のような具合

SELECT a.t_id, a.i_id, b.i_name, a.u_id, c.u_name
FROM log_tbl a
LEFT JOIN item_tbl b ON b.i_id = a.i_id
LEFT JOIN user_tbl c ON c.u_id = a.u_id

上記SQLの結果をphpの配列に入れるのであれば下記のような具合

$temp_array = array();
$sql='省略';
$result = mysql_query($sql) or dir('SQL実行に失敗');
while ($row = mysql_fetch_array($result)) {
 array_push($temp_array, $row);
}
◎質問者からの返答

ご回答ありがとうございます。

無事動作を確認いたしました。

前回もご回答いただきました。

http://q.hatena.ne.jp/1301731001

おかげで、ジョイントの考え方がなんとなくですがイメージできた気がしています。

LEFT JOIN だけですが・・・。

ありがとうございました。

関連質問


●質問をもっと探す●



0.人力検索はてなトップ
8.このページを友達に紹介
9.このページの先頭へ
対応機種一覧
お問い合わせ
ヘルプ/お知らせ
ログイン
無料ユーザー登録
はてなトップ