Աղյուսակի միջոցով կապ ստեղծելը Python-ում
Ենթադրենք, որ օգտատերը եղել է տարբեր քաղաքներում: Այս դեպքում օգտատերերի աղյուսակը կարող է ունենալ հետևյալ տեսքը:
| 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
Հարցման արդյունքը
Մեր հարցման արդյունքը Python-ում կպարունակի յուրաքանչյուր օգտատիրոջ անունը այնքան անգամ, որքան քաղաքների հետ նա կապված է:
{'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'}
{'user_name': 'user5', 'city_name': None}
Ավելի հարմար կլիներ վերափոխել այդպիսի բառարան և վերածել այն հետևյալի:
{
'user1': ['city1', 'city2', 'city3'],
'user2': ['city1', 'city2'],
'user3': ['city2', 'city3'],
'user4': ['city1'],
'user5': []
}
Եկեք գրենք կոդ, որը կկատարի այդպիսի վերափոխում:
Կստեղծենք դատարկ բառարան user_cities_dct,
որի մեջ աստիճանաբար կմուտքագրենք տվյալներ
օգտատերերի և նրանց այցելած քաղաքների մասին:
Ցիկլում for հայտարարում ենք երկու փոփոխական
user_name և city_name, որոնց
մեջ կպահվեն օգտատիրոջ անունը և քաղաքի անվանումը:
Այնուհետև գրում ենք պայման - եթե
օգտատերը չկա user_cities_dct-ում, ապա նա
կավելացվի այդ բառարանում որպես բանալի:
Նաև նշենք պայման, որ եթե city_name
չէ None, ապա այն կավելացվի որպես արժեք
բանալու:
result = cursor.fetchall()
user_cities_dct = {}
for row in result:
user_name = row['user_name']
city_name = row['city_name']
if user_name not in user_cities_dct:
user_cities_dct[user_name] = []
if city_name is not None:
user_cities_dct[user_name].append(city_name)
print(user_cities_dct)
Գործնական առաջադրանքներ
Ենթադրենք, ապրանքը կարող է պատկանել մի քանի կատեգորիաների: Նկարագրեք պահպանման կառուցվածքը:
Գրեք հարցում, որը կբերի ապրանքները նրանց կատեգորիաների հետ միասին:
Ցուցադրեք ստացված տվյալները որպես ցուցակ
ul այնպես, որ յուրաքանչյուր li-ի
մեջ սկզբում լինի ապրանքի անունը, իսկ դրանից հետո
երկ점ից հետո բաժանված ստորակետերով թվարկվեն
այդ ապրանքի կատեգորիաները: Մոտավորապես այսպես:
<ul>
<li>product1: category1, category2, category3</li>
<li>product2: category1, category3</li>
<li>product3: category1</li>
</ul>