A ver, tengo productos, tengo categorías y tengo una tabla que relaciona ambas, de forma que un producto puede estar en varias categorías y cada una de estas contiene varios de aquellos. Total, que para que el usuario filtre por categorías yo puse:
Código SQL
[-]SELECT Productos.*
FROM Productos, RelCategoriasProductos
WHERE Productos.id=RelCategoriasProductos.IdProducto
AND RelCategoriasProductos.IdCategoria IN (a, b, c,...)
Todo iba bien y todos éramos felices, hasta que hoy me han dicho que no, que el filtro por categorías ha de ser excluyente,
useasé, que han de aparecer sólo los productos que estén en
todas las categorías y no en
alguna. De todas las ideas que se me han ocurrido, la única que veo factible es ir producto por producto preguntándole a qué categorías pertenece y comprobando a mano que todas estén ahí.
De repente me he acordado del JOIN, pero es que nunca lo he entendido. Vamos, que por lo que he leído y visto por aquí (a mi jefe le encanta poner sopocientosmil JOIN anidados unos dentro de otros), todo lo que hace el JOIN se puede hacer con consultas sin JOIN (o al menos las que hace mi jefe, o eso me parece a mi).
No sé, ¿a alguien se le ocurre una solución? ¿O es más fácil que eso y me estoy liando por nada?