⊗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 များကို အသုံးပြုပါသည်။ ဒေတာများကို ပြုပြင်ခြင်းသည် ကိုယ်ရေးကိုယ်တာ မူဝါဒအတိုင်း ဖြစ်ပါသည်။
အားလုံးလက်ခံရန် ပြင်ဆင်ရန် ငြင်းပယ်ရန်