| From: | Koen Bok <koen(at)madebysofa(dot)com> |
|---|---|
| To: | pgsql-sql(at)postgresql(dot)org |
| Subject: | Simple Query? |
| Date: | 2007-09-11 21:27:19 |
| Message-ID: | 2C0EA394-5AC8-4FC8-99F3-5FAEE9720360@madebysofa.com |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-sql |
I am doing some optimization on our search, but I need some advise...
table: item
id name
--------------------------------------
1 iPod
2 Zune
3 Walkman
table: search_item
id_search id_item
--------------------------------------
1 1
1 2
1 3
2 2
2 3
3 1
3 3
Now what I want to have is the items that match with id_search 1 and
2 and 3. Therefore I use the following SQL query.
SELECT * FROM item WHERE id IN
(SELECT id_item FROM search_item WHERE id_search=1 AND id_item IN
(SELECT id_item FROM search_item WHERE id_search=2 AND id_item IN
(SELECT id_item FROM search_item WHERE id_search=3)));
This should only return id_item 3. Would this be the best SQL query
to get this result? I have the feeling there should be something
better, but I cannot find it. Anyone has a hint?
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Rodrigo De León | 2007-09-11 21:46:17 | Re: Simple Query? |
| Previous Message | Josh Tolley | 2007-09-11 17:29:19 | Re: Does postgresql8.2 supports multithreading? |