PHP-ում աղյուսակի միջոցով կապ ստեղծելը
Ենթադրենք, որ օգտագործողը եղել է տարբեր քաղաքներում: Այս դեպքում օգտագործողների աղյուսակը կարող է ունենալ հետևյալ տեսքը.
| id | name | city |
|---|---|---|
| 1 | user1 | city1, city2, city3 |
| 2 | user2 | city1, city2 |
| 3 | user3 | city2, city3 |
| 4 | user4 | city1 |
Հասկանալի է, որ այսպես տվյալներ պահելը սխալ է - քաղաքները պետք է տեղափոխել առանձին աղյուսակ: Ահա այն.
| id | name |
|---|---|
| 1 | city1 |
| 2 | city2 |
| 3 | city3 |
Սակայն, մենք պետք է անենք այնպես, որ յուրաքանչյուր օգտագործող կարողանա հղվել մի քանի քաղաքների: Երկու աղյուսակի օգնությամբ դա անհնար է անել:
Մեզ անհրաժեշտ կլինի ներմուծել այսպես կոչված կապի աղյուսակ, որը կկապի օգտագործողին նրա քաղաքների հետ:
Այս աղյուսակի յուրաքանչյուր գրառման մեջ կպահվի կապը օգտագործողի և մեկ քաղաքի միջև: Այս դեպքում մեկ օգտագործողի համար այս աղյուսակում կլինի այնքան գրառում, քանի քաղաքներում նա եղել է:
Ահա մեր կապի աղյուսակը.
| 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 |
Օգտագործողների աղյուսակը կպահի միայն օգտագործողների անունները առանց կապերի.
| 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>