Cadena de tablas relacionadas en Python
Supongamos que ahora los usuarios viven en ciertas ciudades, y estas ciudades están ubicadas en diferentes países. En este caso, para el almacenamiento necesitaremos tres tablas: los usuarios estarán vinculados con las ciudades, y las ciudades - con los países. Además, no necesitaremos un campo de enlace de usuarios con países, ya que los usuarios de todos modos estarán vinculados con los países a través de la relación entre ciudades y países.
Echemos un vistazo a nuestras tablas. Tabla con países:
| id | name |
|---|---|
| 1 | country1 |
| 2 | country2 |
Tabla con ciudades:
| id | name | country_id |
|---|---|---|
| 1 | city1 | 1 |
| 2 | city2 | 1 |
| 3 | city3 | 2 |
La tabla con usuarios permanecerá sin cambios:
| id | name | city_id |
|---|---|---|
| 1 | user1 | 1 |
| 2 | user2 | 1 |
| 3 | user3 | 2 |
| 4 | user4 | 1 |
| 5 | user5 | 3 |
| 6 | user6 | 2 |
Consultas
Para obtener a los usuarios junto con sus ciudades y países, tendremos que hacer dos uniones (joins): la primera unirá las ciudades a los usuarios, y la segunda - los países a las ciudades:
SELECT
users.name,
cities.name as city_name,
countries.name as country_name
FROM
users
LEFT JOIN cities ON cities.id=users.city_id
LEFT JOIN countries ON countries.id=cities.country_id
Tareas prácticas
Supongamos que los productos pertenecen a una subcategoría específica, y las subcategorías pertenecen a una categoría específica. Describa la estructura de almacenamiento.
Escriba una consulta que obtenga los productos, junto con sus subcategorías y categorías.
Escriba una consulta que obtenga las subcategorías junto con sus categorías.