http://oshiete1.goo.ne.jp/kotaeru.php3?q=1069795
で質問した続きです。
うっかり詳細のテストをしてないのに締め切ってしまいました。
テーブルA 「member」
| id | name |
テーブルB 「item」
| id | name |
テーブルC 「item_check」
| member_id | item_id |
というテーブルがあります。
テーブルAはメンバーで一人一つのデータが入っています。
テーブルBはメンバーが持つであろうアイテムのマスタです。
テーブルCはメンバーがどのアイテムを持っているかを示しているテーブルです。
テーブルCに関しては同じメンバーでも複数のアイテムを持つこともあるので複数のデータが入る場合もあります。
で、やろうとしているのは、
「アイテムA と アイテムBを持っているメンバー」
という検索を行いたいのです。
select distinct a.id, a.name from member as a,item as b,item_check as c
where a.id = c.member_id and c.item_id = b.id
and (c.item_id = '2' or c.item_id = '3')
select member.*,item.name from member, item, item_check
where member.id=item_check.member_id and item.id=item_check.item_id and item.id in (1, 3) group by member.id
で or 検索はできますが、
and 検索をすると 「Empty set」となってしまいます。
select distinct a.id, a.name from member as a,item as b,item_check as c
where a.id = c.member_id and c.item_id = b.id
and (c.item_id = '2' and c.item_id = '3')
なにかいい手はないでしょうか。
No.2ベストアンサー
- 回答日時:
こんにちは。
ごめんなさい、意味がわかりました・・・。
>>アイテムA と アイテムBを持っているメンバー
両方持ってるメンバーだけという事ですね?
まずはitem_checkのテーブルからmember_idだけを抽出します。
SELECT member_id, count(member_id)
FROM item_check
WHERE item_id = 'A' OR item_id = 'B'
GROUP BY member_id
HAVING count(member_id) > 1 --ここの数値は条件のアイテム数と合わせてね。
これでとりあえずmember_idが取れるので、
後は副問い合わせとかで引っ付けてください。
(^^ゞ
この回答への補足
質問文が分かりづらいようでした。すいません。
Mysql のバージョンが 4.0.21 の為副問い合わせが使えません。
たしか 4.1 からでしたよね。
ベータ版なのであえて避けて正式版の方を使っています。
そうなるとやっぱりクエリを分けなくてはいけないのですか?
一回で出るに越したことはありませんが。
(というか早いほうがいいのですが)
テストして検討をしてみます。
SELECT * FROM item_check,member,item WHERE member.id = member_id and item.id = item_check.item_id and (item_id = '2' OR item_id = '3') GROUP BY member.id HAVING count(member_id) >= 2
テストした結果、これで一発で出るようです。
ありがとうございました。
まだ知らないことってたくさんあるんですね。
MysqlのWEBマニュアルを見ても分かりづらいので・・・
周りにスペシャリストがいないので助かりました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・ハマっている「お菓子」を教えて!
- ・最近、いつ泣きましたか?
- ・夏が終わったと感じる瞬間って、どんな時?
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
全角文字を含む行を検索
-
エクセルで最後の文字だけ置き...
-
エクセルの関数について教えて...
-
VIEWの元のテーブルのindexって...
-
Mysql でレコードを追加した時...
-
mysqlのdeleteのサブクエリーで...
-
SQL Left Join で重複を排除す...
-
NOT NULL 制約の削除
-
フォームで 保存ボタンを押して...
-
クエリ表示と、ADOで抽出したレ...
-
引数について
-
エラー 1068 (42000): 複数の主...
-
チェックしてますか?
-
横浜駅周辺でプルコギが食べら...
-
LEFT JOIN と GROUP BY
-
VMware Player でCD-ROMドライ...
-
PL/SQLの変数について
-
mysqlのload data infileで連番...
-
入力値と外部キーをINSERTするには
-
SQLサーバから、項目の属性(型...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
エクセルの関数について教えて...
-
副問合せの書き方について
-
SQLサーバから、項目の属性(型...
-
VIEWの元のテーブルのindexって...
-
マイクラPC版のコマンドで効率...
-
SQL Left Join で重複を排除す...
-
エラー 1068 (42000): 複数の主...
-
select文のwhere句に配列を入れ...
-
バインド変数について
-
SQLにて特定の文字を除いた検索...
-
Access パラメータクエリをcsv...
-
WordpressのContact form 7でzi...
-
PL/SQLの変数について
-
1テーブル&複数レコードの更新...
-
ある条件の最大値+1を初番する...
-
Updateの複数テーブル条件時のL...
-
sqlで、600行あるテーブルを100...
-
”photo id” とは何ぞや?
-
クエリ表示と、ADOで抽出したレ...
おすすめ情報