⊗pyPmDOChLT 124 of 129 menu

Cadeia de Tabelas Relacionadas em Python

Suponha que agora os usuários moram em determinadas cidades, e essas cidades estão localizadas em diferentes países. Nesse caso, para armazenamento, precisaremos de três tabelas: os usuários estarão vinculados às cidades, e as cidades - aos países. Dessa forma, não precisaremos de um campo de ligação dos usuários com os países - pois os usuários já estarão vinculados aos países através do vínculo das cidades e países.

Vamos dar uma olhada em nossas tabelas. A tabela de países:

countries
id name
1 country1
2 country2

A tabela de cidades:

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

A tabela de usuários permanecerá inalterada:

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

Consultas

Para obter os usuários junto com suas cidades e países, teremos que fazer dois joins: o primeiro unirá as cidades aos usuários, e o segundo - os países às cidades:

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

Tarefas Práticas

Suponha que os produtos pertencem a uma determinada subcategoria, e as subcategorias pertencem a uma determinada categoria. Descreva a estrutura de armazenamento.

Escreva uma consulta que obtenha os produtos, junto com suas subcategorias e categorias.

Escreva uma consulta que obtenha as subcategorias junto com suas categorias.

Português
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Nós usamos cookies para o funcionamento do site, análises e personalização. O processamento de dados é realizado de acordo com a Política de Privacidade.
aceitar todas configurar rejeitar