Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 07-05-2019
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
Cita:
Empezado por Casimiro Notevi Ver Mensaje
Pero sigues sin decir lo único que debes decir: qué quieres conseguir.
Está puesto: necesito, entre otros datos, la identidad de dos fichas de acuerdo con unas condiciones. Esta parte de la consulta puede devolver ninguna respuesta, una o dos, pero nunca más de dos, y de ahí estar usando un JOIN
Responder Con Cita
  #2  
Antiguo 07-05-2019
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.052
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por Angel.Matilla Ver Mensaje
Está puesto: necesito, entre otros datos, la identidad de dos fichas de acuerdo con unas condiciones. Esta parte de la consulta puede devolver ninguna respuesta, una o dos, pero nunca más de dos, y de ahí estar usando un JOIN
entre otros datos... qué datos.
la identidad de dos fichas... qué fichas.
de acuerdo con unas condiciones... qué condiciones.
puede devolver ninguna respuesta, una o dos, pero nunca más de dos, y de ahí estar usando un JOIN... absolutamente nada que ver.

Ángel, no sabemos qué quieres conseguir exactamente, solamente vemos el select que has hecho y que dices que no sirve.
Tienes que decir algo así como "necesito los registros de la tabla zona donde el codigo esté en municipio y que su poblacion sea la del usuario de la tabla partido que tenga fecha entre aaaa y bbbb que esté en la tabla censo y que su fecha de alta sea del año pasado y su nombre sea luis.
Por decir algo.
Responder Con Cita
  #3  
Antiguo 07-05-2019
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
Tienes razón. ¿Ves como me iba a costar explicarlo? Dejadme pensarlo un poco como lo cuento.
Responder Con Cita
  #4  
Antiguo 07-05-2019
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
A ver si ahora soy capaz de hacerme entender. Tengo que meter este query:
Código PHP:
SELECT A.CodigoA.NombreA.ApellidosA.JuntaB.Cargo
  FROM Persona A LEFT JOIN Electos B ON B
.Cargo 33
 WHERE A
.Poblacion 1837
   
AND A.Codigo B.Codigo
   
AND A.Junta = (SELECT Codigo FROM Junta WHERE Municipio A.Poblacion
dentro del que puse antes. En este caso concreto sé que debe devolver una única fila y, tal cual está aquí, lo hace bien. Sin embargo, si lo amplio para que me devuelva las dos posibles situaciones que busco poniéndolo así:
Código PHP:
SELECT A.CodigoA.NombreA.ApellidosA.JuntaB.Cargo,
       
C.CodigoC.NombreC.ApellidosC.JuntaD.Cargo
  FROM Persona A LEFT JOIN Electos B ON B
.Cargo 33,
       
Persona C LEFT JOIN Electos D ON D.Cargo 34
 WHERE A
.Poblacion 1837
   
AND A.Codigo B.Codigo
   
AND A.Junta = (SELECT Codigo FROM Junta WHERE Municipio A.Poblacion)
   AND 
A.Poblacion C.Poblacion
   
AND C.Codigo D.Codigo
   
AND C.Junta = (SELECT Codigo FROM Junta WHERE Municipio C.Poblacion
que debería devolverme los mismos datos del primer query más una serie de celdas vacías ya que en este caso no hay ninguna ficha que cumpla la condición de PRESIDENTE, no me devuelve absolutamente nada. Ese el meollo, añadido a que si lo que funciona lo acoplo en el query que ponía en mi mensaje anterior entonces no me devuelve nada. La necesidad de que me lo devuelva todo en una sola fila viene dada porque de este query tengo que sacar un informe impreso.
Responder Con Cita
  #5  
Antiguo 07-05-2019
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.052
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Responder Con Cita
  #6  
Antiguo 07-05-2019
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
¿Qué? ¿Cómo lo ves?
Responder Con Cita
  #7  
Antiguo 07-05-2019
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
Cita:
Empezado por Angel.Matilla Ver Mensaje
Código PHP:
SELECT A.CodigoA.NombreA.ApellidosA.JuntaB.Cargo
  FROM Persona A LEFT JOIN Electos B ON B
.Cargo 33
 WHERE A
.Poblacion 1837
   
AND A.Codigo B.Codigo
   
AND A.Junta = (SELECT Codigo FROM Junta WHERE Municipio A.Poblacion
Voy más allá. Si este query, que me devuelve una única fila (como debe ser por otra parte) lo transformo en este:
Código PHP:
SELECT A.CodigoA.NombreA.ApellidosA.JuntaB.Cargo
  FROM Persona A LEFT JOIN Electos B ON B
.Cargo 33 AND A.Codigo B.Codigo
 WHERE A
.Poblacion 1837
   
AND A.Junta = (SELECT Codigo FROM Junta WHERE Municipio A.Poblacion
En principio esta sintaxis me parece que también es correcta; corregidme si me equivoco. Me devuelve 37 filas: la correcta y 36 que no sé que pinta ahí porque la columna B.Cargo la devuelve en todos ellos como Null.
Responder Con Cita
  #8  
Antiguo 07-05-2019
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.052
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Ángel, como he comentado antes, y creía que lo habías entendido, todo eso no nos sirve de nada.
Lo único que necesitamos saber es qué datos necesitas, de qué tablas, con qué parámetros, etc. y eso todavía no lo sabemos.
¿Seguro que has leído y has entendido lo que te enlacé antes?
Responder Con Cita
  #9  
Antiguo 07-05-2019
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
Cita:
Empezado por Casimiro Notevi Ver Mensaje
Ángel, como he comentado antes, y creía que lo habías entendido, todo eso no nos sirve de nada.
Lo único que necesitamos saber es qué datos necesitas, de qué tablas, con qué parámetros, etc. y eso todavía no lo sabemos.
¿Seguro que has leído y has entendido lo que te enlacé antes?
Sinceramente que no sé como explicarme mejor: Los datos que necesito son los que se ven ahí: Identidad de la ficha a partir de las tablas Persona y Electos de las que antes mostré la definición, para un código de población determinado (en el ejemplo uso ese código 1837 porque sé que en este caso sólo hay uno de los dos registros posibles) y para dos códigos de cargo: 33 y 34. No sé que más información puede hacer falta.
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
Problemas con consulta left outer join hebam SQL 4 06-09-2007 03:43:27
usando LEFT JOIN o RIGHT JOIN alcides SQL 8 03-05-2007 17:35:46
left join e inner join duda Patricio SQL 0 26-04-2007 22:06:43
Problemas con un left outer join en FB2 TJose Firebird e Interbase 12 19-02-2007 14:11:38
LEFT OUTER JOIN e INNER JOIN Juntos alcides SQL 3 08-07-2005 18:06:27


La franja horaria es GMT +2. Ahora son las 11:09:12.


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