FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
Consulta que se resiste, Clausula IN
Tengo la siguiente estructura de base de datos para relacionar categorias con direcciones
y quiero obetener las direcciones que estan simultaneamente en mas de una categoria, es decir, quiero que me devuelva las direcciones que por ejemplo son clientes y proveedores al mismo tiempo. Como veis es una relacion de n a n y no me sale esa consulta. He intentado con la clausula IN de la siguiente forma: Código SQL [-]SELECT DISTINCT DIRECCIONES.COD_DIRECCION, DIRECCIONES.C_CONT FROM DIRECCIONES INNER JOIN DIR_CAT ON (DIRECCIONES.COD_DIRECCION = DIR_CAT.ID_DIR) INNER JOIN CATEGORIAS ON (DIR_CAT.ID_CAT = CATEGORIAS.ID_CATEGORIA) WHERE (CATEGORIAS.CATEGORIA = :Q) AND ((DIRECCIONES_COD_DIRECCION, DIRECCIONES.C_CONT) IN ( SELECT DISTINCT DIRECCIONES.COD_DIRECCION, DIRECCIONES.C_CONT FROM DIRECCIONES INNER JOIN DIR_CAT ON (DIRECCIONES.COD_DIRECCION = DIR_CAT.ID_DIR) INNER JOIN CATEGORIAS ON (DIR_CAT.ID_CAT = CATEGORIAS.ID_CATEGORIA) WHERE (CATEGORIAS.CATEGORIA = :P)) Y me da un error en el IN. Un saludo y gracias.
__________________
Intentando hacer algo con Delphi 7 y Firebird 1.5 |
#2
|
|||
|
|||
No estoy seguro, pero prueba con algo así:
|
#3
|
||||
|
||||
Sigue intentado hacerlo con este código
y dinos qué tal. Suerte.
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino - |
#4
|
||||
|
||||
Hola, no me ha funcionado ninguna de las dos , la clauula union puede ser la solucion? pero no me funciona, me da error
__________________
Intentando hacer algo con Delphi 7 y Firebird 1.5 |
#5
|
||||
|
||||
O te hemos entendido mal o no te explicas bien ( lo primero, seguro ).
He vuelto a leer la duda, y con mi consulta debiera salir perfectamente la información que quieres.
Te tiene que salir esto ( siempre que tengas registros repetidos ). COD_DIRECCION, VECES uno,2 dos,3 cuatro, 5 Si quieres ir filtrando, prueba quitando la clausula HAVING
COD_DIRECCION, VECES uno,2 dos,3 tres,1 cuatro, 5 cinco,1 seis,1 Observa que he quitado de la consulta el parámetro Q que tú incluías, que puede ser el motivo de que no te funcione. Aunque realmente és lo mismo que no funcione a que no te salga la información que quieres. Suerte y un saludo
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino - |
#6
|
||||
|
||||
Ya consegui hacer que funcionara, al final me quedo algo asi:
Un saludo y gracias a todos por la ayuda.
__________________
Intentando hacer algo con Delphi 7 y Firebird 1.5 |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Edit se resiste a recibir foco... | aprendiz2 | OOP | 4 | 16-12-2006 01:41:06 |
Google se resiste a revelar la base de datos de sus usuarios | vtdeleon | Noticias | 2 | 24-01-2006 16:23:16 |
Clausula LIKE | federiconqn21 | SQL | 3 | 28-12-2005 15:49:13 |
Delete sin clausula where | Fita | Conexión con bases de datos | 2 | 06-07-2005 01:35:04 |
Clausula UNION | TJose | Firebird e Interbase | 3 | 15-05-2003 20:59:56 |
|