⊗ppPmDOLVT 384 of 447 menu

Propojení přes spojovací tabulku v PHP

Nyní předpokládejme, že uživatel byl v různých městech. V tomto případě by tabulka s uživateli mohla mít následující podobu:

users
id name city
1 user1 city1, city2, city3
2 user2 city1, city2
3 user3 city2, city3
4 user4 city1

Je zřejmé, že takto ukládat data není správně - města je třeba vyčlenit do samostatné tabulky. Zde je:

cities
id name
1 city1
2 city2
3 city3

Avšak potřebujeme zajistit, aby každý uživatel mohl odkazovat na několik měst. S použitím dvou tabulek to není možné.

Budeme muset zavést takzvanou spojovací tabulku, která bude propojovat uživatele s jeho městy.

V každém záznamu této tabulky bude uloženo propojení mezi uživatelem a jedním městem. Přitom pro jednoho uživatele bude v této tabulce tolik záznamů, kolika měst se týká.

Zde je naše spojovací tabulka:

users_cities
id user_id city_id
1 1 1
2 1 2
3 1 3
4 2 1
5 2 2
6 3 2
7 3 3
8 4 1

Tabulka s uživateli bude uchovávat pouze jména uživatelů, bez propojení:

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

Dotazy

Vytvořme dotaz, pomocí kterého získáme uživatele spolu s jejich městy. K tomu budeme potřebovat provést dva spojení (JOIN): první JOIN připojí k uživatelům spojovací tabulku, a druhý JOIN přes spojení připojí města:

SELECT users.name as user_name, cities.name as city_name FROM users LEFT JOIN users_cities ON users_cities.user_id=users.id LEFT JOIN cities ON users_cities.city_id=cities.id

Výsledek dotazu

Výsledek našeho dotazu v PHP bude obsahovat jméno každého uživatele tolikrát, s kolika městy je propojen:

<?php $arr = [ ['user_name' => 'user1', 'city_name' => 'city1'], ['user_name' => 'user1', 'city_name' => 'city2'], ['user_name' => 'user1', 'city_name' => 'city3'], ['user_name' => 'user2', 'city_name' => 'city1'], ['user_name' => 'user2', 'city_name' => 'city2'], ['user_name' => 'user3', 'city_name' => 'city2'], ['user_name' => 'user3', 'city_name' => 'city3'], ['user_name' => 'user4', 'city_name' => 'city1'], ]; ?>

Bylo by pohodlnější takové pole překonvertovat a přeměnit jej na následující:

<?php $res = [ ['user1' => ['city1', 'city2', 'city3']], ['user2' => ['city1', 'city2']], ['user3' => ['city2', 'city3']], ['user4' => ['city1']], ]; ?>

Napišme kód, který provádí takovou konverzi:

<?php $res = []; foreach ($data as $elem) { $res[$elem['user_name']][] = $elem['city_name']; } var_dump($res); ?>

Praktické úlohy

Předpokládejme, že produkt může patřit do několika kategorií. Popište strukturu uložení.

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

Zobrazte získaná data ve formě seznamu ul tak, aby v každé li nejprve stálo jméno produktu a za dvojtečkou čárkou odděleně vyjmenovány kategorie tohoto produktu. Přibližně takto:

<ul> <li>product1: category1, category2, category3</li> <li>product2: category1, category3</li> <li>product3: category1</li> </ul>
Č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