Data Query Language
Last updated
Was this helpful?
Last updated
Was this helpful?
Database ထဲက data တွေကိုဆွဲထုတ်လိုတဲ့အချိန်မှာ DQLလို့ခေါ်တဲ့ query တွေကိုအသုံးပြုပါတယ်။ SELECT
ကိုအသုံးပြုပြီး အနောက်မှာ condition အခြေအနေအမျိုးမျိုးလိုက်ကာ data တွေကို filter လုပ်နိုင်ဖို့အတွက် WHERE
ဆိုတဲ့ keyword ကိုသုံးပါတယ်။ ဒီအပိုင်းမှာတော့ DQL ကိုပေါ်လွင်အောင်ရိုးရှင်းတဲ့နမူနာ queries တွေနဲ့အတူလေ့လာသွားကြပါမယ်။
MySQL command line client ကိုဖွင့်ပြီးတော့ DQL queries တွေစမ်းရေးကြည့်ဖို့အတွက် database အသစ်တစ်ခုဆောက်ရအောင်။
CREATE DATABASE dql_test;
ဆောက်ပီးရင်သုံးဖို့အတွက် ready ဖြစ်အောင် use dql_test;
ဆိုပြီးလုပ်ပေးထားလိုက်ပါမယ်။
DQL queries တွေစမ်းဖို့အတွက် products
ဆိုတဲ့ table တစ်ခုဆောက်ပါမယ်။
Table ဆောက်ပြီးပြီးဆိုတော့ dummy data တစ်ချို့ထည့်သွင်းပါမယ်။ INSERT
statement ကိုသုံးပါမယ်။
DQL ဖြစ်တဲ့အတွက်ဒီအပိုင်းမှာ SELECT
နဲ့ WHERE
keyword ကိုအဓိကသုံးသွားမှာဖြစ်ပြီးတော့ query schema ကတော့အောက်ပါအတိုင်းဖြစ်ပါတယ်။
Condition နေရာမှာတော့လိုအပ်သလိုပုံစံမျိုးစုံလိုက်နိုင်ပါတယ်။ အောက်ကနမူနာတွေမှာဆက်ဖော်ပြပေးထားပါတယ်။
ပထမဦးဆုံး products table ထဲကနေ category
column က Electronics
ဖြစ်တဲ့ value ကိုဆွဲထုတ်ကြည့်ပါမယ်။ column value အားလုံးလိုချင်တဲ့အတွက် * ကိုသုံးပါမယ်။
တူညီတဲ့ value ကိုလိုချင်တဲ့အတွက် =
sign ကိုအသုံးပြုပါတယ်။
ဈေးနှုန်း price column ကို 100 ကျော်တဲ့ records တွေကိုဆွဲထုတ်ကြည့်ပါမယ်။ *
မသုံးဘဲနဲ့လိုချင်တဲ့ column တွေကိုပဲ comma နဲ့ဖြတ်ပြီးသတ်မှတ်ပေးလိုက်ပါမယ်။
100ကျော်
တဲ့ records ဆိုတဲ့အတွက် >
sign ကိုအသုံးပြုပါတယ်။ အောက်ရောက်တယ်ဆိုရင် <
less than sign ကိုသုံးပါမယ်။
အားလုံးသိပြီးထားတဲ့ sign တွေအတိုင်းပါပဲ
less than and equal ဆို ≤
greater than and equal ဆို ≥
အသုံးပြုပါတယ်။
ဒီတစ်ခါ AND
ဆိုတဲ့ keyword ကိုသုံးပြီး condition နှစ်ခု combine လုပ်ကြည့်ပါမယ်။ လွယ်ကူပါတယ်၊ condition နှစ်ခုကြားမှာအောက်ကလို AND
ဆိုပြီးခံပေးလိုက်ရုံပါပဲ။
condition ကတော့ stock_quantity column ကို 50 အောက်ရောက်နေပြီးတော့ ဈေးနှုန်းက 20 ထက်ကြီးတဲ့ records တွေကိုဆွဲထုတ်ပါမယ်။
ဒီတစ်ခါတော့ product_name
မှာ Smart
ဆိုတဲ့ value ပါတဲ့ records တွေကိုဆွဲထုတ်ပါမယ်။
keyword နဲ့တိုက်ပီးရှာချင်တယ်ဆိုရင် %
sign ကိုအသုံးပြုပါတယ်။
WHERE column_name LIKE 'abc%'
% sign ကနောက်မှာ value ကရှေ့မှာဆို abc နဲ့စတဲ့ values ရှာမယ်။
WHERE column_name LIKE '%a'
% sign ကရှေ့မှာ value ကနောက်မှာဆို abc နဲ့ဆုံးတဲ့ values ရှာမယ်။
WHERE column_name LIKE '%abc%'
% sign ကိုရှေ့နောက်နှစ်ခုလုံးကပ်ထားမယ်ဆိုနေရာမရွေးဘဲရှာမယ်။
supplier
တန်ဖိုးက NULL
ဖြစ်နေ (မရှိနေ)တဲ့ records တွေကိုဆွဲထုတ်ကြည့်ပါမယ်။
Range တန်ဖိုးတွေဆက်ဆွဲထုတ်ကြည့်ရအောင်၊ ဘယ်တန်ဖိုးကနေ ဘယ်တန်ဖိုးအထိဆိုတာမျိုးပေါ့။
WHERE
နောက်မှာ BETWEEN
နဲ့ AND
keyword ကိုလိုက်ပြီးအသုံးပြုနိုင်ပါတယ်။
BETWEEN
နောက်မှာအစတန်ဖိုး၊ AND
နောက်မှာအဆုံးတန်ဖိုးထည့်ပါမယ်။
အပေါ်မှာတုန်းကတူတဲ့ value ဆိုချင်ရင် =
ဆိုတဲ့ sign ကိုအသုံးပြုခဲ့တယ်။
=
က value တစ်ခုပဲ assign လုပ်ချင်ပေမယ့် value တစ်ခုထက်ပိုပြီးထည့်သုံးချင်တဲ့အခါ IN
ဆိုတဲ့ keyword ကိုပြောင်းသုံးရပါမယ်။
category
column က Clothing
ဒါမှမဟုတ် Accessories
ဖြစ်တဲ့ records တွေကိုဆွဲထုတ်ကြည့်ပါမယ်။
IN
ရဲ့ပြောင်းပြန် NOT IN
ကိုသုံးလိုက်မယ်ဆိုရင်တော့အဲ့ဒီ value တွေမပါတဲ့ records တွေကိုဆွဲထုတ်ပေးပါလိမ့်မယ်။ အောက်က screenshot မှာ result ကိုကြည့်နိုင်ပါတယ်။
value ကတစ်ခုတည်းဆိုရင်တော့ NOT IN
ကိုမသုံးဘဲ NOT
ဆိုတဲ့ keyword တစ်ခုတည်းနဲ့လည်းအသုံးပြုနိုင်ပါတယ်။
အောက်မှာဆိုရင် category
က Furniture
မဟုတ်တဲ့ records တွေကိုဆွဲထုတ်ထားတာဖြစ်ပါတယ်။
DQL ရဲ့သဘောက data တွေကိုမိမိလိုချင်သလိုဆွဲထုတ်နိုင်ဖို့ပါပဲ၊ ဒီလိုဆွဲထုတ်ဖို့အတွက် SELECT နဲ့ WHERE ကဘယ်လောက်ထိအရေးပါလဲဆိုတာအထက်က queries တွေကိုကြည့်ရင်မြင်နိုင်ပါတယ်။ အခု article မှာတော့ DQL သဘောပေါ်လွင်အောင် ရိုးရှင်းတဲ့ query တွေကိုပဲအသုံးပြုထားပါသေးတယ်။ နောက်ပိုင်းမှာ advance ဖြစ်တဲ့ query တွေနဲ့ data ဆွဲထုတ်ပုံတွေကိုလည်းဆက်လက်ရေးသားပေးပါမယ်။