Dame tu dirección para enviarte un regalo de navidad jajaja. Que buen aporte, me sirvio mucho, gracias infinitas.
Esta imagen es muy útil. Se debe tener en cuenta que el full join no aplica para todos los manejadores de bases de datos.
Muchas gracias :)
gracias por el aporte!
Para ser el curso práctico me parece que tiene mucha teoría... :|
jajajajaja, cierto!!
Yo creo que empieza excelente este curso. Tener claro conceptualmente estos comandos hace más poderosas nuestras queries al comprender que es lo que hacen y como funcionan cada uno de ellos. IMHO.
este imágenes son mi formulario me han ayudado mucho mientras aprendo bases de datos:
estas son las mas: usadas:
aqui se mencionan algunas formas de join que son implicitas (semi join):
en estas ultimas se muestran algunas relaciones entre 3 o mas tablas, sin embargo en el poco camino que llevo aprendiendo sql... aun no las he usado:
Gracias!
Cual es la diferencia entre el inner join y el non equi inner join?
El profe hablando del join mostrando un enredo y yo pensando en mis notas de obsidian
Solo una cosa puede superar lo perfecto y es lo estandarizado, por ello importante crear un criterio de uso
Les comparto una prueba que hice para entender bien el tema de los join, esta en la web de Kaggle, sin código es complicado tenerlo claro:
/*Creando tabla propietarios 'owners'*/CREATETABLEpublic.owners( id serial, name varchar(50)NOTNULL, age smallint NOTNULL);/*Se me olvido el campo pet_id y lo he tenido que ingresar con ALTER TABLE*/ALTERTABLEpublic.ownersADD pet_id integer NULL;/*Agregando la clave primaria*/ALTERTABLEpublic.ownersADDPRIMARYKEY(id);/*Creando tabla de mascotas 'pets'*/CREATETABLEpublic.pets( id serial, name varchar(50)NOTNULL, age smallint NOTNULL, animal varchar(50)NOTNULL);/*Agregando la clave primaria de mascotas 'pets'*/ALTERTABLEpublic.petsADDPRIMARYKEY(id);/*Agregando la clave foranea a la tabla 'owners' haciendo referencia a la tabla 'pets'*/ALTERTABLEpublic.ownersADDCONSTRAINT fkpet
FOREIGNKEY(pet_id)REFERENCESpublic.pets(id);/*Insertando valores de prueba*/INSERTINTOpublic.owners(name, age, pet_id)VALUES('Aubrie Little',20,1),('Chett Crawfish',45,3),('Jules Spinner',10,4),('Magnus Burnsides',9,2),('Veronica Dunn',8,NULL);INSERTINTOpublic.pets(name, age, animal)VALUES('Dr. Harris Bonkers',1,'Rabbit'),('Moon',9,'Dog'),('Ripley',7,'Cat'),('Tom',2,'Cat'),('Maisie',10,'Dog');/*
----------------------------------------------------------
Obtenemos todos los valores de la tabla propietarios o dueños, independientemente de si tiene valores que coinciden en la tabla pets.
LEFT JOIN hace referencia a la tabla que esta asignada antes del JOIN es decir owner
*/SELECTow.nameAS owner_name, pt.nameAS pet_name
FROMpublic.ownersAS ow
LEFTJOINpublic.petsAS pt
ON(ow.pet_id= pt.id);/*
Obtenemos todos los valores de la tabla mascotas, independientemente de si tiene valores que coinciden en la tabla propietarios.
RIGHT JOIN hace referencia a la tabla que esta asignada despues del JOIN es decir pets
*/SELECTow.nameAS owner_name, pt.nameAS pet_name
FROMpublic.ownersAS ow
RIGHTJOINpublic.petsAS pt
ON(ow.pet_id= pt.id);/*
Trae todos los valores de ambas tablas, independientemente si estan conectados, en las filas que no tienen coincidencias se rellenan con valores NULL
*/SELECTow.nameAS owner_name, pt.nameAS pet_name
FROMpublic.ownersAS ow
FULLJOINpublic.petsAS pt
ON(ow.pet_id= pt.id);
SELECT *
FROM tabla_diaria AS td ---> Selecciona la tabla indicada y le da el alias de "td"
JOIN tabla_mensual AS tm ---> Relaciona la tabla diaria con la tabla mensual y la renombre con el alias "tm"
ON tdpk = tmfk; ---> Relaciona la llave principal ".pk" (primary key) con la llave foránea ".fk" (foranean key).
Se debe tener cuidado al realizar productos cartesianos pues se puede llegar a una solución muy compleja.
Left Join: Toma la tabla de la izquierda y conserva todos sus elementos junto con los elementos de la segunda tabla que pertenezcan a al primera tabla.
Right Join:Toma la tabla de la derecha y conserva todos sus elementos junto con los elementos de la segunda tabla que pertenezcan a al primera tabla.
Exclusive Left Join: Toma los elementos de la tabla de la izquierda pero que NO están en la tabla de la derecha.
Exclusive Right Join: Toma los elementos de la tabla de la izquierda pero que NO están en la tabla de la derecha.
Full Outer Join: Trae todos los elementos de la primera tabla y todos los elementos de la segunda tabla.
Excusive Full Outer Join: Trae los elementos que existen en la primera tabla y los elementos de la segunda tabla pero que NO son en común
Inner Join: Cuando no se específica el tipo de Join, por default se ejecuta este. Que trae solamente los elementos en común de las tablas
Estos son solo ejemplos simples, y las consultas pueden variar según tus necesidades específicas.
6. Productos cartesianos (JOIN)
Sacar todos los datos de todas las tablas que tengo involucradas.
No es deseable hacer todos contra todos.
Tener equivalente a cada join en los diagramas de Venn
SELECT*FROM tabla_diaria AS td
JOIN tabla_mensual AS tm
ON td.pk = tm.fk;
Left Join
Elementos que existen a A, sin importar que estén en B.
Right Join
Elementos que existen en B, sin importar que estén en A.
Exclusive Left Join
Lo que existe en A que no exista en B.
Exclusive Right Join
Lo que existe en B que no exista en A.
Full Outer Join — Rara vez se ocupa — No es muy performante
Todo lo de A con todo lo de B.
Exclusive Full Outer Join
Todo lo de A con todo lo de B, excepto lo que coincida.
Inner Join — Más común — Default
Solamente lo que tengan en común las tablas A y B.
++Prod. Cartesiano (JOIN)++
Es la combinación de más de una tabla a través de una o más sentencias de relación
Normalmente se usa una Primary Key y una Foreign Key
Israel tiene magia para explicar, se nota tu amor por los datos, sin lugar a dudas tus cursos solos valen la sucripción de Platzi
Recuerda que al hacer JOINS y unir tablas, en algunos casos puedes tener información duplicada en las dimensiones, así que siempre debes estar validando no estar duplicando la información, o analizarla de forma correcta, para el tema de análisis de datos debemos siempre validar que la info que estamos mostrando es real.
ejemplo de consulta, con tablas relacionadas!
INNER JOIN: Combina filas de dos o más tablas basándose en una condición.
SELECT*FROM tabla1 INNERJOIN tabla2 ON tabla1.columna = tabla2.columna;
LEFT JOIN (o LEFT OUTER JOIN): Retorna todas las filas de la tabla izquierda y las filas coincidentes de la tabla derecha.
SELECT*FROM tabla1 LEFTJOIN tabla2 ON tabla1.columna = tabla2.columna;
RIGHT JOIN (o RIGHT OUTER JOIN): Retorna todas las filas de la tabla derecha y las filas coincidentes de la tabla izquierda.
SELECT*FROM tabla1 RIGHTJOIN tabla2 ON tabla1.columna = tabla2.columna;
FULL JOIN (o FULL OUTER JOIN): Retorna filas cuando hay una coincidencia en una de las tablas.
SELECT*FROM tabla1 FULLJOIN tabla2 ON tabla1.columna = tabla2.columna;
CROSS JOIN: Retorna el producto cartesiano de ambas tablas.
SELECT*FROM tabla1 CROSSJOIN tabla2;
Quisiera saber como se explica según esto un self join lo he visto aplicado para algunos casos pero no me queda clara la lógica... gracias!
Self Join es una característica muy particular de SQL, es cuando se consulta una columna referenciándose a una referencia en común como si se tratara de un relacion foránea,
te dejo un link donde te explican con un audio y con una interfaz interactiva como funciona claramente.