Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #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.000
Poder: 25
Ñ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?
__________________
Proyectos actuales --> Allegro 5 Pascal ¡y Delphi!|MinGRo Game Engine
Responder Con Cita
  #2  
Antiguo 06-07-2011
Saklut Saklut is offline
Registrado
 
Registrado: mar 2007
Posts: 4
Poder: 0
Saklut Va por buen camino
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).
Responder Con Cita
  #3  
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.000
Poder: 25
Ñuño Martínez Tiene un aura espectacularÑuño Martínez Tiene un aura espectacular
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.
__________________
Proyectos actuales --> Allegro 5 Pascal ¡y Delphi!|MinGRo Game Engine
Responder Con Cita
  #4  
Antiguo 06-07-2011
Avatar de ContraVeneno
ContraVeneno ContraVeneno is offline
Miembro
 
Registrado: may 2005
Ubicación: Torreón, México
Posts: 4.738
Poder: 24
ContraVeneno Va por buen camino
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"....
__________________

Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

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


La franja horaria es GMT +2. Ahora son las 07:59:45.


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