Ver Mensaje Individual
  #1  
Antiguo 06-07-2011
Avatar de Ñuño Martínez
Ñuño Martínez Ñuño Martínez is offline
Moderador
 
Registrado: jul 2006
Ubicación: Ciudad Catedral, Españistán
Posts: 6.025
Reputación: 27
Ñuño Martínez Tiene un aura espectacularÑuño Martínez Tiene un aura espectacular
¿El JOIN sirve para esto?

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?
Responder Con Cita