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 26-08-2003
Viet Viet is offline
Miembro
 
Registrado: jul 2003
Ubicación: Argentina - Mar del Plata
Posts: 252
Poder: 21
Viet Va por buen camino
Angry Left Outer Join en MSSQL

Muy buenas mis colegas!!!!

estoy tratando de hacer algo muy simple que he resuelto muchas veces en MySql pero en MSSql no me funciona..

Mi consulta es esta:

select apellido , nombre , c.conexion_pedida

from empleados
left outer join conexion_requerida c on( empleados.id_empleado=c.id_empleado)

y quiero obtener un listado de todos los empleados y si existe un registro en la tabla c con el mismo id_empleado, me tendria que dar la conexion_pedida, y sino NULL...

porque en MSSQL no funciona !!!

Muchas Gracias por su tiempo
__________________
Marín Ignacio Borthiry (Viet) - "El hombre arriesga su vida cada vez que elije y eso es lo que lo hace libre" ;)
Responder Con Cita
  #2  
Antiguo 26-08-2003
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
Hola.

El left outer join de MS SQL funciona como lo define el estándar (imagino que igual que hará MySQL), por lo que esa consulta debería devolverte lo que buscas :

Todos los empleados, con un registro para cada una de sus conexiones. Si un empleado no tiene ninguna conexión sale un solo registro para el empleado con la conexión en nulo.

Mira a ver si el problema no está en otra parte (los datos en las tabals, los campos que relacionen las tablas), .... Porqué la consulta debería funcionar.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #3  
Antiguo 26-08-2003
Viet Viet is offline
Miembro
 
Registrado: jul 2003
Ubicación: Argentina - Mar del Plata
Posts: 252
Poder: 21
Viet Va por buen camino
Hola Marc y gracias por tu pronta respuesta,

La verdad es que he mirado los datos y son correctos, pero la repuesta es como si estubiese haciendo un INNER JOIN, porque tengo 1600 empleados (donde todos tienen un ID_empleado distinto, ya que es Autoincremental) y en la tabla de conexiones tengo 950 registros distintos , cada uno con un ID_empleado distinto.... pero el resultado final es de 950 regitros....

La verdad me tiene bastante confundido
__________________
Marín Ignacio Borthiry (Viet) - "El hombre arriesga su vida cada vez que elije y eso es lo que lo hace libre" ;)
Responder Con Cita
  #4  
Antiguo 26-08-2003
Viet Viet is offline
Miembro
 
Registrado: jul 2003
Ubicación: Argentina - Mar del Plata
Posts: 252
Poder: 21
Viet Va por buen camino
Perdón.... pero me olvide de aclarar algo muy importante

Estoy poniendo en el Where de la Query una condicion con la tabla Conexiones

Seguramente eso me esta dando el problema, no?

creo que encontre la solucion.... si pongo :


left outer join conexion_requerida c on (empleados.id_empleado=c.id_empleado and (datepart(dy,c.fecha) =datepart(dy,getdate()-1)))

en vez de ponerlo en el Where me trae todos los registros


pero no se si es correcto poner mas condiciones en el Where y si se pueden poner en cualquier orden
__________________
Marín Ignacio Borthiry (Viet) - "El hombre arriesga su vida cada vez que elije y eso es lo que lo hace libre" ;)

Última edición por Viet fecha: 26-08-2003 a las 19:24:37.
Responder Con Cita
  #5  
Antiguo 26-08-2003
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
Hola Viet.

En efecto, esa parece la causa del problema.

Puedes añadir perfectamente esa condición en el ON del left outer join, funcionará como esperas (y el orden no es importante, puesto que es exactamente lo mismo a and b que b and a).

Otra opción, si prefieres poner la cláusula en el Where, como tenías inicialmente, es ponerla para que solo se tenga en cuenta, si hay un registro relacionado :

Código:
select apellido , nombre , c.conexion_pedida
from empleados 
     left outer join conexion_requerida c on empleados.id_empleado = c.id_empleado
where c.id_empleado is null or
      datepart(dy, c.fecha) = datepart(dy, getdate() - 1)
O sea la condición es :

O no hay registro relacionado (c.id_empleado es nulo), o bien ese registro relacionado es de ayer.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #6  
Antiguo 26-08-2003
Viet Viet is offline
Miembro
 
Registrado: jul 2003
Ubicación: Argentina - Mar del Plata
Posts: 252
Poder: 21
Viet Va por buen camino
Thumbs up

Cada dia me sorprendes mas con la claridad de tus respuestas


Muchas Gracias y Saludos desde Argentina!
__________________
Marín Ignacio Borthiry (Viet) - "El hombre arriesga su vida cada vez que elije y eso es lo que lo hace libre" ;)
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


La franja horaria es GMT +2. Ahora son las 12:20:34.


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