Catena di tabelle collegate
Supponiamo ora che gli utenti vivano in città specifiche, e che queste città si trovino in diversi paesi. In questo caso, per la memorizzazione avremo bisogno di tre tabelle: gli utenti saranno collegati alle città, e le città ai paesi. In questo modo non avremo bisogno di un campo di collegamento diretto tra utenti e paesi - poiché gli utenti saranno comunque collegati ai paesi attraverso il collegamento tra città e paesi.
Diamo un'occhiata alle nostre tabelle. La tabella dei paesi:
| id | name |
|---|---|
| 1 | country1 |
| 2 | country2 |
La tabella delle città:
| id | name | country_id |
|---|---|---|
| 1 | city1 | 1 |
| 2 | city2 | 1 |
| 3 | city3 | 2 |
La tabella degli utenti rimarrà invariata:
| id | name | city_id |
|---|---|---|
| 1 | user1 | 1 |
| 2 | user2 | 1 |
| 3 | user3 | 2 |
| 4 | user4 | 1 |
| 5 | user5 | 3 |
| 6 | user6 | 2 |
Query
Per ottenere gli utenti insieme alle loro città e paesi, dovremo effettuare due join: il primo unirà le città agli utenti, e il secondo i paesi alle città:
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
Compiti pratici
Supponiamo che i prodotti appartengano a una specifica sottocategoria, e che le sottocategorie appartengano a una specifica categoria. Descrivete la struttura di memorizzazione.
Scrivi una query che recuperi i prodotti, insieme alle loro sottocategorie e categorie.
Scrivi una query che recuperi le sottocategorie insieme alle loro categorie.