Hi everyone! I'm the author of code.mu :)
I'd love to chat with my non-Russian audience. I'm looking for your feedback on the site and the translation quality. Let's chat:)
⊗ppSpOtSQ 80 of 83 menu

PHP တွင် SQL အသုံးပြုမှုအား အဆင့်မြှင့်တင်ခြင်း

ဒေတာဘေ့စ်သို့ SQL မေးမြန်းချက်များ လုပ်ဆောင်ခြင်းသည် အလွန်နှေးကွေးသော လုပ်ဆောင်ချက်တစ်ခုဖြစ်သည်။ ထို့ကြောင့် ဒေတာဘေ့စ်သို့ မေးမြန်းချက်အရေအတွက်ကို လျှော့ချရန် ကြိုးစားသင့်ပါသည်။

အပြုသဘောဆောင်သော အမှားမှာ ကွင်းဆက်အတွင်းတွင် SQL မေးမြန်းချက်များစွာ လုပ်ဆောင်ခြင်းဖြစ်ပြီး၊ ဆန္ဒရှိရာကို command တစ်ခုတည်းဖြင့် လုပ်ဆောင်နိုင်သော အခြားရွေးချယ်စရာ မေးမြန်းချက်များ ရှိနေပါသည်။

ဥပမာဖြင့် ကြည့်ရအောင်။

ကျွန်ုပ်တို့တွင် ဒေတာဘေ့စ်ရှိ မှတ်တမ်း id များပါသော အခင်းအကျင်းတစ်ခု ရှိသည်ဆိုပါစို့။ ထိုကဲ့သို့သော id များဖြင့် မှတ်တမ်းများအား ဖျက်ရန်လိုအပ်သည်။

အချိန်ကြာမြင့်စွာ စဉ်းစားခြင်းမရှိဘဲ၊ အောက်ပါ "အံ့သြဖွယ်" တည်ဆောက်မှုကို ရေးနိုင်ပါသည်။

<?php $ids = [1, 2, 3, 4, 5]; // ဖျက်ရန်အတွက် အခင်းအကျင်း foreach ($ids as $id) { mysqli_query($link, "DELETE FROM users WHERE id=$id"); } ?>

ဤကုဒ်၏ပြဿနာမှာ ကွင်းဆက်အတွင်းတွင် မေးမြန်းချက်များစွာ လုပ်ဆောင်ခြင်းကြောင့်ဖြစ်သည်။ အခင်းအကျင်းထဲတွင် အရာဝတ္ထု 100 ခု ရှိမည်ဟု စိတ်ကူးကြည့်ပါ - ဒေတာဘေ့စ်သို့ မေးမြန်းချက် 100 ခု လုပ်ဆောင်ပါလိမ့်မည်။

ဖော်ပြပါတာဝန်၏ အထူးထောင်ချောက်မှာ ဝဘ်ဆိုက်တည်ဆောက်သည့်အခါ ဒေတာဘေ့စ်သည် သေးငယ်ပြီး မေးမြန်းချက်များသည် အလွန်လျင်မြန်စွာ လုပ်ဆောင်ခြင်းဖြစ်သည်။ �ို့သော်၊ ဆာဗာပေါ်တွင် ဝဘ်ဆိုက်လုပ်ဆောင်သည်နှင့်အမျှ ဒေတာဘေ့စ်သည် ကြီးထွားလာမည်၊ မေးမြန်းချက်များသည် ပိုမိုနှေးကွေးစွာ လုပ်ဆောင်လာမည်၊ ကွင်းဆက်အတွင်း မေးမြန်းချက်ရာပေါင်းများစွာ လုပ်ဆောင်ခြင်းကြောင့် ဝဘ်ဆိုက်သည် တစ်မိနစ်ကျော် ဝန်ခံယူနေရနိုင်သည်။

အားအနည်းငယ်သာထည့်သွင်းခြင်းဖြင့်၊ မေးမြန်းချက်တစ်ခုတည်းသာ လုပ်ဆောင်ရန် ဤကဲ့သို့လုပ်နိုင်သည်။

<?php $ids = [1, 2, 3, 4, 5]; $str = implode(',', $ids); // စာကြောင်း '1,2,3,4,5' ကိုရရှိမည် mysqli_query($link, "DELETE FROM users WHERE id IN ($str)"); ?>

အောက်ပါကုဒ်ကို အဆင့်မြှင့်တင်ပါ။

<?php $arr = [1, 2, 2, 4, 5]; $res = []; for ($i = 1; $i < count($arr); $i++) { $note = mysqli_query($link, "SELECT * FROM users WHERE id=$id"); for ($data = []; $row = mysqli_fetch_assoc($note); $data[] = $row); $res[] = $data; } var_dump($res); ?>
မြန်မာ
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 များကို အသုံးပြုပါသည်။ ဒေတာများကို ပြုပြင်ခြင်းသည် ကိုယ်ရေးကိုယ်တာ မူဝါဒအတိုင်း ဖြစ်ပါသည်။
အားလုံးလက်ခံရန် ပြင်ဆင်ရန် ငြင်းပယ်ရန်