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

MySQL4.1.12において以下の2つのテーブルを結合したいのですがうまくいきません

テーブルA(ファイル管理テーブル)
file_id, file_name, file_cat

テーブルB(閲覧権限管理テーブル)
file_id, user_id

条件)
ファイルの名前は一つ目から最後まで常に表示し、ユーザーが閲覧権限を持っていれば”閲覧”ボタンを表示。持っていなければ”申請”ボタン
を表示する形にしたい

例えば以下のようにLEFT JOINすると該当ユーザー以外の情報も含まれた形で結果を取得してしまいます
例)SELECT a.file_id, a.file_name, b.user_id FROM a LEFT JOIN b ON a.doc_id = b.doc_id

また、where句を追加し該当ユーザーに絞り込むと両方のテーブルでマッチした行しか結果が取得できなくなってしまいます
例)SELECT a.file_id, a.file_name, b.user_id FROM a LEFT JOIN b ON a.doc_id = b.doc_id where user_id = 該当ユーザーのID

なんとかしてすべてのファイルの名前+該当ユーザーのみの閲覧権限が結合した結果を取得したいのですがよい方法はないでしょうか(代替案でもけっこうです)
どんぴしゃかつ具体的な回答をいただけた場合は300ポイント差し上げます

●質問者: jayz
●カテゴリ:ウェブ制作
✍キーワード:ON SELECT どんぴしゃ ファイル ボタン
○ 状態 :終了
└ 回答数 : 1/1件

▽最新の回答へ

1 ● b-wind
●300ポイント ベストアンサー

4.1 ならサブクエリが使えますね。

SELECT a.file_id, a.file_name,
 EXISTS ( SELECT * FROM b WHERE a.doc_id = b.doc_id where user_id = ${user_id} ) AS permit
FROM a;

な感じかな。

◎質問者からの返答

ありがとうございます。どんぴしゃです

あぁ、いろいろ調べたのにこういうやりかたがあったんですね。。。

関連質問


●質問をもっと探す●



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