例を挙げます。
テーブルA 「member」
| ID | 名前 |
テーブルB 「item」
| ID | 名前 |
テーブルC 「item_check」
| member.ID | item.ID |
というテーブルがあります。
テーブルAはメンバーで一人一つのデータが入っています。
テーブルBはメンバーが持つであろうアイテムのマスタです。
テーブルCはメンバーがどのアイテムを持っているかを示しているテーブルです。
テーブルCに関しては同じメンバーでも複数のアイテムを持つこともあるので複数のデータが入る場合もあります。
で、やろうとしているのは、
「アイテムA と アイテムBを持っているメンバー」
という検索を行いたいのです。
同じテーブル上ならば
select * from member where item1 = "A" and item2 = 'B' ... ;
と、いくつでも条件が指定可能なのですが、
同じテーブルの同じフィールドを同じメンバーで複数条件指定して検索することはできるのでしょうか。
私が考えたのは一回ではできないで、
まずは一つの条件を出して
while でループさせて条件を付け足してやるような効率が悪そうなものです。
(少ない件数ならばいいのですが、数千~数万件の検索になりそうなので手軽にできればと思いまして・・・)
アイテムは不特定なので、1個から数十個とかの検索もありえます。
何かいい手はないでしょうか。
No.1ベストアンサー
- 回答日時:
できますよ。
andというのは「AかつB」という条件ですが、orというのが「AまたばB」という条件を作れます。
select distinct a.id, a.名前 from member as a,item as b,item_check as c
where a.id = c.member.id and c.item.id = b.id
and (item_check.item.id = 'A' or item_check.item.id = 'B')
これでいかがでしょう?
item.idがAまたはBのアイテムを持っている人を抽出しているはずです。
ところでカラム名に.って使えますか?
できましたー。
ありがとうございます。
テーブルもカンマ(,)で区切って複数指定できるんですね。知りませんでした。
フィールドで使えるのは知っていましたが。
ちなみにカラム名に . は使えないと思います。
分かりやすくするために例のような形式にしました。
No.3
- 回答日時:
#2です。
ごめん。間違った。置き換えれるのは、「item.id=1 and item.id=3」じゃなくて「item.id=1 or item.id=3」だった。
andをorに直してくらはい。
No.2
- 回答日時:
確認事項:各テーブルの中身
member
ID|名前
1|あんもち
2|ムーンライト
item
ID|名前
1|おにぎり
2|しゃけ
3|ゆでたまご
item_check
memberid|itemid
1|1
1|2
2|1
2|3
これでよいのかな? これを踏まえた上で↓。
------------
できるよ。
select member.*
from member, item, item_check
where member.id=item_check.memberid and item.id=item_check.itemid
and item.id in (1, 3)
これで普通にできると思うけどな。
一番下の行 item.id in (1, 3)のかっこの中を動的に変えれば良い。これは次のように置き換える事もできる。「item.id=1 and item.id=3」
ちなみに例に示したSQL文が返すのは
member.id|member.名前
1|あんもち
2|ムーンライト
2|ムーンライト
例えばこれで、「該当するアイテムを1個でも持っている人を1回のみ抽出」という事であれば、DBにもよるけどdistinctを使う事になる。
具体的な例を挙げての回答ありがとうございました。
やりたいことは or( in() ) ではなく、 and ですので、and で使用します。
select member.* 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
と、group by を使用すれば 重複なしでmemberが出てきますし、問題が解決しました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Access(アクセス) AccessVBAで降順にするテーブル作成クエリを使用して作成したテーブルを削除し同一のテーブル作成 1 2023/01/06 11:17
- Oracle SQL update方法 2 2022/06/22 14:07
- その他(データベース) 更新クエリをリンクデータベーステーブルに実行し実行時エラー3362固有インデックスに重複する値が含ま 1 2022/09/21 11:44
- Access(アクセス) アクセスの更新クエリでカレントレコードのみ更新したい 1 2022/06/02 23:32
- Oracle sqlで質問です。 Aテーブルの情報をBテーブルに更新かけたいです。 やりたいことは、Bテーブルの受 1 2023/05/17 11:17
- その他(データベース) accessでの請求管理について 2 2022/06/13 21:51
- Ruby pandasでsqlite3にテーブル作成・追加・読み出しでindexの取り扱い方教えてください 5 2023/03/08 09:57
- JavaScript html javascriptにてWeb SQLを操作したい。 2 2022/12/16 17:43
- MySQL 複数DBテーブルからのデータ取得 3 2022/05/17 15:02
- Oracle sqlで質問です。 aテーブルとbテーブルがあり、下記のsqlで取得したidとnameに一致しないレ 1 2022/04/20 20:34
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQLサーバから、項目の属性(型...
-
SQL Left Join で重複を排除す...
-
副問合せの書き方について
-
[MySQL] UNIQUE制約の値を更新...
-
select文のwhere句に配列を入れ...
-
SQLにて特定の文字を除いた検索...
-
selectした大量データをinsert...
-
エクセルの関数について教えて...
-
sqlで、600行あるテーブルを100...
-
MySQLのint型で001と表示する方...
-
VIEWの元のテーブルのindexって...
-
複数テーブルのGROUP BY の使い...
-
Unionした最後にGROUP BYを追加...
-
Access パラメータクエリをcsv...
-
LAST_INSERT_IDで同時にアクセ...
-
PL/SQLの変数について
-
[SQLServer] テーブル名からカ...
-
VMwareがCDドライブを認識する...
-
1対多結合で多を絞り込み条件と...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
副問合せの書き方について
-
SQLサーバから、項目の属性(型...
-
VIEWの元のテーブルのindexって...
-
select文のwhere句に配列を入れ...
-
selectした大量データをinsert...
-
センノシド異性体構造式
-
Unionした最後にGROUP BYを追加...
-
insertを高速化させたい
-
SQLにて特定の文字を除いた検索...
-
マイクラPC版のコマンドで効率...
-
ある条件の最大値+1を初番する...
-
inner joinをすると数がおかし...
-
sqlで、600行あるテーブルを100...
-
エクセルの関数について教えて...
-
Access パラメータクエリをcsv...
-
URL と行番号の指定
-
複数テーブルのGROUP BY の使い...
-
PL/SQLの変数について
おすすめ情報