⊗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हिन्दीMagyarIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Մենք օգտագործում ենք cookie-ներ կայքի աշխատանքի, վերլուծության և անհատականացման համար։ Տվյալների մշակումը կատարվում է համաձայն Գաղտնիության քաղաքականության։
ընդունել բոլորը կարգավորել մերժել