⊗pyPmDOChLT 124 of 129 menu

Řetězec spojených tabulek v Pythonu

Nyní předpokládejme, že uživatelé žijí v určitých městech a tato města se nacházejí v různých zemích. V takovém případě pro uložení budeme potřebovat již tři tabulky: uživatelé budou spojeni s městy a města - se zeměmi. Při tom nebudeme potřebovat pole spojení uživatelů se zeměmi - protože uživatelé budou stejně spojeni se zeměmi přes spojení měst a zemí.

Podívejme se na naše tabulky. Tabulka se zeměmi:

countries
id name
1 country1
2 country2

Tabulka s městy:

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

Tabulka s uživateli zůstane nezměněna:

users
id name city_id
1 user1 1
2 user2 1
3 user3 2
4 user4 1
5 user5 3
6 user6 2

Dotazy

Pro to, abychom získali uživatele spolu s jejich městy a zeměmi, budeme muset provést dva spojení (JOIN): první připojí města k uživatelům a druhý - země k městům:

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

Praktické úlohy

Předpokládejme, že produkty patří do určité podkategorie a podkategorie patří do určité kategorie. Popište strukturu uložení.

Napište dotaz, který získá produkty, spolu s jejich podkategoriemi a kategoriemi.

Napište dotaz, který získá podkategorie spolu s jejich kategoriemi.

Čeština
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Používáme soubory cookie pro fungování webu, analýzu a personalizaci. Zpracování údajů probíhá v souladu s Zásadami ochrany osobních údajů.
přijmout vše přizpůsobit odmítnout