Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   ¿El JOIN sirve para esto? (https://www.clubdelphi.com/foros/showthread.php?t=74708)

Ñuño Martínez 06-07-2011 11:18:56

¿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?

Saklut 06-07-2011 12:06:10

A ver si esto te vale:

Código SQL [-]
Select Productos.*
  from Productos
 where Productos.id in
       (select Productos.id
          from RelCategoriasProductos
         WHERE RelCategoriasProductos.IdCategoria IN (a, b, c)
         group by Productos.id
        having count(*) = 3)

OJO: en la última línea debes poner la cantidad de categorías (en este caso 3).

Ñuño Martínez 06-07-2011 12:37:37

Gracias Saklut.

Precisamente he estado un buen rato comentándolo con un compañero vía gTalk! y al final llegamos a la misma consulta que has puesto tú. Pero idéntica, oyes. Se ve que es La Solución, porque funciona perfectamente (por ahora).

Como ya he dicho, eso de las consultas anidadas no lo controlo todavía. :o

ContraVeneno 06-07-2011 17:30:32

Cualquier consulta es más rápida cuando utilizas "joins", yo te recomendaría que les dieras una buena revisada para que llegaras a entenderlos. Así estaba yo al principio, todo lo hacía con subconsultas o todas las tablas en el from. Cuando llegue a entender los "joins", me evite muchos dolores de cabeza.

Solo los productos que esten en todas las categorías seleccionadas:

Código SQL [-]
Select P.ID, P.Nombre
From Productos P
Join Categorias C on P.ID = C.IDProducto and C.IDCategoria in (a, b, c)
Group by P.ID, P.Nombre

Si quisieras ver el detalle, simplemente quitas el "Group By", cosa que no podrías hacer con la subconsulta.

Si quieres todos los productos sin importar las categorías, simplementa cambias el "join" por un "left outer join" y listo, con la subonsulta, tendrías que modificar varias cosas, si no es que toda la consulta.

Eso sin considerar que con el join es solo una consulta, no varias, lo que implica un mejor desempeño. Y todavía podrías filtrarla utilizan un where.. en fin, infinidad de opciones.

Como dije, yo te recomendaría que le diras una buena revisada a los "joins"....


La franja horaria es GMT +2. Ahora son las 01:09:48.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi