⊗pyPmDOLVT 125 of 129 menu

Աղյուսակի միջոցով կապ ստեղծելը Python-ում

Ենթադրենք, որ օգտատերը եղել է տարբեր քաղաքներում: Այս դեպքում օգտատերերի աղյուսակը կարող է ունենալ հետևյալ տեսքը:

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

Հարցման արդյունքը

Մեր հարցման արդյունքը 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>
Հայերեն
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-ներ կայքի աշխատանքի, վերլուծության և անհատականացման համար։ Տվյալների մշակումը կատարվում է համաձայն Գաղտնիության քաղաքականության։
ընդունել բոլորը կարգավորել մերժել