Legătură dublă cu o singură tabelă în PHP
Să presupunem că avem orașe:
| id | name |
|---|---|
| 1 | city1 |
| 2 | city2 |
| 3 | city3 |
Să presupunem că avem rute între orașe, unde fiecare rută are un oraș de plecare și un oraș de sosire:
| id | name | from_city_id | to_city_id |
|---|---|---|---|
| 1 | route1 | 1 | 2 |
| 2 | route2 | 2 | 3 |
Să presupunem că vrem să obținem rutele împreună cu orașele. Complexitatea aici constă în faptul că fiecare rută are două orașe: plecare și sosire.
Rezultă că tabela cu orașe trebuie să fie join-uită de două ori. La fiecare join tabela va trebui redenumită:
SELECT
from_cities.name as from_city_name,
to_cities.name as to_city_name
FROM
routes
LEFT JOIN cities as from_cities
ON from_cities.id=routes.from_city_id
LEFT JOIN cities as to_cities
ON to_cities.id=routes.to_city_id
Să presupunem că avem utilizatori. Fiecare utilizator are tată și mamă. Descrieți structura de stocare.