⊗ppPmDOLVT 384 of 447 menu

PHP တွင် ဆက်သွယ်မှုဇယားမှတစ်ဆင့် ချိတ်ဆက်ခြင်း

ယခု user သည် မြို့များစွာတွင် ရှိခဲ့သည်ဆိုပါစို့။ ဤအခြေအနေတွင် user များပါဝင်သော ဇယားသည် အောက်ပါပုံစံရှိနိုင်သည်။

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

သို့ရာတွင်၊ user တစ်ဦးစီသည် မြို့များစွာကို ညွှန်းဆိုနိုင်ရန် လုပ်ဆောင်ရမည်။ ဇယားနှစ်ခုဖြင့် ဤသို့လုပ်ဆောင်ရန် မဖြစ်နိုင်ပါ။

ကျွန်ုပ်တို့သည် ခေါ်ဆိုသော ဆက်သွယ်မှုဇယား ကို ထည့်သွင်းရန် လိုအပ်သည်၊ ၎င်းသည် user ကို ၎င်း၏မြို့များနှင့် ချိတ်ဆက်ပေးမည်ဖြစ်သည်။

ဤဇယားရှိ မှတ်တမ်းတစ်ခုစီတွင် user နှင့် မြို့တစ်မြို့အကြား ဆက်သွယ်မှုကို သိမ်းဆည်းမည်။ ဤသို့ဖြင့် user တစ်ဦးအတွက် ဤဇယားတွင် သူရှိခဲ့သော မြို့အရေအတွက်အတိုင်း မှတ်တမ်းများ ရှိမည်။

ကျွန်ုပ်တို့၏ ဆက်သွယ်မှုဇယားမှာ ဤသို့ဖြစ်သည်။

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

User များပါဝင်သော ဇယားသည် user အမည်များကိုသာ သိမ်းဆည်းမည်၊ ဆက်သွယ်မှုများ မပါဝင်ပါ။

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

Query များ

User များကို ၎င်းတို့၏မြို့များနှင့်အတူ ထုတ်ယူနိုင်မည့် query တစ်ခုကို လုပ်ဆောင်ကြပါစို့။ ထိုသို့လုပ်ဆောင်ရန် join နှစ်ခု လိုအပ်မည်။ ပထမ join သည် user များထံသို့ ဆက်သွယ်မှုဇယားကို ချိတ်ဆက်မည်၊ ဒုတိယ join သည် ဆက်သွယ်မှုများမှတစ်ဆင့် မြို့များကို ချိတ်ဆက်မည်။

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

Query ၏ ရလဒ်

PHP တွင် ကျွန်ုပ်တို့၏ query ၏ ရလဒ်သည် user တစ်ဦးစီ၏ အမည်ကို ၎င်းသည် မည်မျှသော မြို့များနှင့် ဆက်သွယ်ထားသည်ဆိုသည့် အကြိမ်အရေအတွက်အတိုင်း ပါဝင်မည်။

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

ထိုကဲ့သို့သော array ကို ပြောင်းလဲပြီး အောက်ပါအတိုင်း ဖြစ်အောင်လုပ်ရန် ပိုမိုအဆင်ပြေမည်။

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

ထိုကဲ့သို့သော ပြောင်းလဲမှုကို လုပ်ဆောင်သော code ကို ရေးကြပါစို့။

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

လက်တွေ့လေ့ကျင့်ခန်းများ

ထုတ်ကုန်တစ်ခုသည် ကဏ္ဍများစွာတွင် ပါဝင်နိုင်သည်ဆိုပါစို့။ သိမ်းဆည်းမှု ဖွဲ့စည်းပုံကို ရေးချပါ။

ထုတ်ကုန်များကို ၎င်းတို့၏ကဏ္ဍများနှင့်အတူ ရယူနိုင်မည့် query တစ်ခုကို ရေးပါ။

ရရှိသော ဒေတာများကို စာရင်း 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МакедонскиMelayuNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
ဝက်ဘ်ဆိုက် လုပ်ဆောင်ခြင်း၊ ဆန်းစစ်လေ့လာခြင်းနှင့် ပုဂ္ဂလိကပြုပြင်ခြင်းအတွက် ကျွန်ုပ်တို့သည် cookie များကို အသုံးပြုပါသည်။ ဒေတာများကို ပြုပြင်ခြင်းသည် ကိုယ်ရေးကိုယ်တာ မူဝါဒအတိုင်း ဖြစ်ပါသည်။
အားလုံးလက်ခံရန် ပြင်ဆင်ရန် ငြင်းပယ်ရန်