Пусть теперь юзеры живут в определенных городах, а эти города расположены в разных странах. В таком случае для хранения нам понадобятся уже три таблицы: юзеры будут связаны с городами, а города - со странами. При этом нам не нужно будет поле связи юзеров со странами - ведь юзеры и так будут связаны со странами через связь городов и стран.
Давайте посмотрим на наши таблицы. Таблица со странами:
id | name |
---|---|
1 | country1 |
2 | country2 |
Таблица с городами:
id | name | country_id |
---|---|---|
1 | city1 | 1 |
2 | city2 | 1 |
3 | city3 | 2 |
Таблица с юзерами останется неизменной:
id | name | city_id |
---|---|---|
1 | user1 | 1 |
2 | user2 | 1 |
3 | user3 | 2 |
4 | user4 | 1 |
5 | user5 | 3 |
6 | user6 | 2 |
Запросы
Для того, чтобы достать юзеров вместе с их городами и странами, нам придется сделать два джоина: первый присоединит города к юзерам, а второй - страны к городам:
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
Практические задачи
Пусть товары принадлежат определенной подкатегории, а подкатегории принадлежат определенной категории. Распишите структуру хранения.
Напишите запрос, который достанет товары, вместе с их подкатегориями и категориями.
Напишите запрос, который достанет подкатегории вместе с их категориями.