⊗ppPmDOChLT 383 of 447 menu

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:

countries
id name
1 country1
2 country2

La tabella delle città:

cities
id name country_id
1 city1 1
2 city2 1
3 city3 2

La tabella degli utenti rimarrà invariata:

users
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.

Italiano
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesia日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Utilizziamo i cookie per il funzionamento del sito, l'analisi e la personalizzazione. I dati vengono elaborati in conformità con la Politica sulla privacy.
accetta tutto personalizza rifiuta