Ver Mensaje Individual
  #2  
Antiguo 22-12-2005
Avatar de Paoti
Paoti Paoti is offline
Miembro
 
Registrado: may 2003
Ubicación: Monterrey. N.L., México
Posts: 612
Reputación: 22
Paoti Va por buen camino
Left outer join

Hola durbed....


¿Qué motor de base de datos usas?



Con Inner join mostrará los registros que cumplan obligatoriamente con la igualdad.

Con Outer join mostrará todos los registros que trae inner join, más los registros de una tabla y otra que no son compatibles con la igualdad, por lo tanto vendrán con valor null del lado donde no se cumpla....


Cita:
Hola

Veamos

Con un inner join, ha de existir una relación entre los registros de ambas tablas. Si esta relación no existe, no se mostrará ningún registro de ninguna de las dos tablas

Con un left/rigth outer join, lo que consigues es que se visualicen todos los registros de la primera/segunda tabla (según sea left o rigth) sin necesidad de la existencia de la relación entre ambas tablas. Hay pocos motores (al menos de los que yo he tocado ninguno) que tengan implementado el rigth, pero bueno, en el estándar está definido al menos.

Por si no te ha quedado clara la explicación de Nuria o mia, veamos un ejemplo

Tenemos una tabla de clientes con un campo CP (codigo postal) que hace referencia a la tabla de poblaciones (por general tb influiría el país, pero bueno, vamos ha hacerlo simple)

Pues bien, si tu quieres mostrar por pantalla tus clientes con el nombre de la población, has de hacer un left outer join, ya que quieres TODOS los clientes tengan o no informado el campo de CP

Código:
select *
from clientes c
left outer join poblaciones p on (p.cp = c.cp)

En cambio, si quieres hacer un mailing, no tiene sentido que imprimas aquellos clientes que no tienen el campo CP informado, ya que no les llegará el correo, por lo que has de hacer un inner join

Código:
select *
from clientes c
inner join poblaciones p on (p.cp = c.cp)


Bueno, espero que entre las explicaciones y el ejemplo te quede claro el uso de inner y outer

Nos leemos

Vsss

Obtenido de
http://www.clubdevelopers.com/foros/...prev_next=prev


NaCl-U2
__________________
Estudia y anda en la calle.... que asi serás el doble de listo que los demás...

análisis de información
análisis y diseño de sistemas

Paoti Rios Reséndiz
Responder Con Cita