FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
¿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:
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? |
#2
|
|||
|
|||
A ver si esto te vale:
OJO: en la última línea debes poner la cantidad de categorías (en este caso 3). |
#3
|
||||
|
||||
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. |
#4
|
||||
|
||||
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:
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"....
__________________
|
Herramientas | Buscar en Tema |
Desplegado | |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
¿Para que sirve Delphi? | MARVIALI | Varios | 6 | 14-10-2010 18:48:00 |
Para que sirve un Actionlist | pnsd_89 | Varios | 3 | 13-08-2007 18:43:23 |
¿Qué es Silverlight y para que sirve? | REHome | Debates | 1 | 07-06-2007 04:50:12 |
dbo.num ?? para que sirve? | sakuragi | SQL | 2 | 15-12-2005 10:46:22 |
Para que sirve DBExpress ? | David | Conexión con bases de datos | 2 | 19-01-2004 21:30:44 |
|