⊗ppPmDOLVT 384 of 447 menu

Звязванне праз табліцу звязку ў PHP

Хай цяпер юзер быў у розных гарадах. У гэтым выпадку табліца з юзерамі магла б мець наступны выгляд:

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

Зразумела, што так захоўваць даныя няправільна - гарады трэба вынесці ў асобную табліцу. Вось яна:

cities
id name
1 city1
2 city2
3 city3

Аднак, нам трэба зрабіць так, каб кожны юзэр мог спасылацца на некалькі гарадоў. З дапамогай двух табліц гэта зрабіць немагчыма.

Нам спатрэбіцца ўвесці так званую табліцу звязку, якая будзе звязваць юзера з яго гарадамі.

У кожным запісе гэтай табліцы будзе захоўвацца сувязь паміж юзерам і адным горадам. Пры гэтым для аднаго юзера ў гэтай табліцы будзе столькі запісаў, у колькіх гарадах ён быў.

Вось наша табліца звязку:

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

Табліца з юзерамі будзе захоўваць толькі імёны юзераў, без сувязяў:

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

Запыты

Давайце зробім запыт, з дапамогай якога выцягнем юзераў разам з іх гарадамі. Для гэтага нам спатрэбяцца зрабіць два джойны: першы джойн далучыць да юзераў табліцу звязку, а другі джойн па сувязях далучыць гарады:

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

Вынік запыту

Вынік нашага запыту ў PHP будзе ўтрымліваць імя кожнага юзера столькі разоў, з колькімі гарадамі ён звязаны:

<?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'], ]; ?>

Зручней было б пераканвертаваць такі масіў і ператварыць яго ў наступны:

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

Напішам код, які выконвае такую канвертацыю:

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

Практычныя задачы

Хай тавар можа належаць некалькім катэгорыям. Распішыце структуру захоўвання.

Напішыце запыт, які дастане тавары разам з іх катэгорыямі.

Выведзіце атрыманыя даныя ў выглядзе спісу ul так, каб у кожнай li спачатку стаяла імя прадукту, а пасля двукроп'я праз коску пералічваліся катэгорыі гэтага прадукту. Прыблізна так:

<ul> <li>product1: category1, category2, category3</li> <li>product2: category1, category3</li> <li>product3: category1</li> </ul>
Беларуская
AfrikaansAzərbaycanБългарскиবাংলাČeštinaDanskDeutschΕλληνικά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
Мы выкарыстоўваем cookie для працы сайта, аналітыкі і персаналізацыі. Апрацоўка дадзеных адбываецца згодна Палітыкай канфідэнцыяльнасці.
прыняць усе наладзіць адхіліць