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