├── README.md ├── SUMMARY.md ├── aggregation.md ├── assets ├── datetime_datatypes.png ├── erd.png ├── linux │ ├── linux1.PNG │ ├── linux2.PNG │ ├── linux3.PNG │ ├── linux4.PNG │ ├── linux5.PNG │ ├── linux6.PNG │ └── linux7.PNG ├── mac │ ├── mac1.png │ ├── mac10.png │ ├── mac2.png │ ├── mac3.png │ ├── mac4.png │ ├── mac5.png │ ├── mac6.png │ ├── mac7.png │ ├── mac8.png │ └── mac9.png ├── numeric_datatypes.png ├── queries │ ├── ag │ │ ├── ag1.png │ │ ├── ag2.png │ │ ├── ag3.png │ │ ├── ag4.png │ │ ├── ag5.png │ │ ├── ag6.png │ │ ├── ag7.png │ │ └── ag8.png │ ├── ddl │ │ ├── ddl1.png │ │ ├── ddl10.png │ │ ├── ddl11.png │ │ ├── ddl12.png │ │ ├── ddl2.png │ │ ├── ddl3.png │ │ ├── ddl4.png │ │ ├── ddl5.png │ │ ├── ddl6.png │ │ ├── ddl7.png │ │ ├── ddl8.png │ │ └── ddl9.png │ ├── dml │ │ ├── dml1.png │ │ ├── dml2.png │ │ ├── dml3.png │ │ ├── dml4.png │ │ ├── dml5.png │ │ ├── dml6.png │ │ └── dml7.png │ ├── dnt │ │ ├── dnt1.png │ │ ├── dnt10.png │ │ ├── dnt11.png │ │ ├── dnt12.png │ │ ├── dnt13.png │ │ ├── dnt14.png │ │ ├── dnt2.png │ │ ├── dnt3.png │ │ ├── dnt4.png │ │ ├── dnt5.png │ │ ├── dnt6.png │ │ ├── dnt7.png │ │ ├── dnt8.png │ │ └── dnt9.png │ ├── dql │ │ ├── dql1.png │ │ ├── dql10.png │ │ ├── dql11.png │ │ ├── dql12.png │ │ ├── dql2.png │ │ ├── dql3.png │ │ ├── dql4.png │ │ ├── dql5.png │ │ ├── dql6.png │ │ ├── dql7.png │ │ ├── dql8.png │ │ └── dql9.png │ ├── ds1.png │ ├── ds10.png │ ├── ds11.png │ ├── ds12.png │ ├── ds2.png │ ├── ds3.png │ ├── ds4.png │ ├── ds5.png │ ├── ds6.png │ ├── ds7.png │ ├── ds8.png │ ├── ds9.png │ ├── index │ │ ├── index1.png │ │ ├── index2.png │ │ ├── index3.png │ │ ├── index4.png │ │ ├── index5.png │ │ ├── index6.png │ │ └── index7.png │ ├── join │ │ ├── j1.png │ │ ├── j2.1.png │ │ ├── j2.png │ │ ├── j3.1.png │ │ ├── j3.png │ │ ├── j4.1.png │ │ ├── j4.png │ │ ├── j5.1.png │ │ └── j5.png │ ├── nor │ │ ├── nor1.png │ │ └── nor2.png │ ├── op │ │ ├── op1.png │ │ ├── op2.png │ │ └── op3.png │ ├── rtq │ │ ├── rtq1.png │ │ ├── rtq10.png │ │ ├── rtq11.png │ │ ├── rtq12.png │ │ ├── rtq13.png │ │ ├── rtq14.png │ │ ├── rtq2.png │ │ ├── rtq3.png │ │ ├── rtq4.png │ │ ├── rtq5.png │ │ ├── rtq6.png │ │ ├── rtq7.png │ │ ├── rtq8.png │ │ └── rtq9.png │ ├── sf │ │ ├── sf1.png │ │ ├── sf10.png │ │ ├── sf11.png │ │ ├── sf12.png │ │ ├── sf2.png │ │ ├── sf3.png │ │ ├── sf4.png │ │ ├── sf5.png │ │ ├── sf6.png │ │ ├── sf7.png │ │ ├── sf8.png │ │ └── sf9.png │ ├── tran │ │ ├── tr1.png │ │ ├── tr2.png │ │ ├── tr3.png │ │ ├── tr4.png │ │ ├── tr5.png │ │ ├── tr6.png │ │ ├── tr7.png │ │ └── tr8.png │ └── tri │ │ ├── tr1.png │ │ └── tr2.png ├── string_datatypes.png └── win │ ├── window1.png │ ├── window10.png │ ├── window11.png │ ├── window12.png │ ├── window13.png │ ├── window14.png │ ├── window15.png │ ├── window16.png │ ├── window17.png │ ├── window18.png │ ├── window19.png │ ├── window2.PNG │ ├── window20.png │ ├── window21.png │ ├── window22.png │ ├── window23.png │ ├── window3.PNG │ ├── window4.png │ ├── window5.png │ ├── window6.png │ ├── window7.png │ ├── window8.png │ └── window9.png ├── conclusion.md ├── data&database.md ├── datatypes.md ├── dbms.md ├── ddl.md ├── diving_queries.md ├── dml.md ├── dnt.md ├── dql.md ├── environment_setup.md ├── erd.md ├── index.md ├── joins.md ├── normalization.md ├── operators.md ├── relationship.md ├── rtq.md ├── sf.md ├── sql_intro.md ├── transaction.md └── trigger.md /README.md: -------------------------------------------------------------------------------- 1 | # SQL-101 2 | SQL ကိုလေ့လာချင်တဲ့ beginners တွေအတွက်ရည်ရွယ်ပြီး သင့်တော်မယ့်ကောင်းနိုးရာရာအပိုင်းတွေကိုထုတ်နုတ်ပြီး series လေးလုပ်ထားလိုက်တာဖြစ်ပါတယ်။
3 | 4 | Series ထဲမှာမပါနိုင်တဲ့တစ်ခြားသောအကြောင်းအရာတွေများစွာရှိသေးအတွက် ဒီနေရာကနေလမ်းစတစ်ခုရပြီး ရှေ့ဆက်လေ့လာသွားဖို့အထောက်အကူပြုနိုင်မယ်လို့မျှော်လင့်ပါတယ်။
5 | 6 | လိုအပ်တာတွေရှိရင်လည်း issues & pull request လုပ်ပြီးဝင်ရောက်ဖြည့်စွက်ပေးနိုင်ပါတယ်ခင်ဗျာ။
7 | 8 | အထောက်အကူပြုတယ်ဆို Repo မှာ star ဝင်ပေးသွားနိုင်ပါတယ်ခင်ဗျာ။
9 | 10 | Gitbook ကနေတစ်ဆင့်လွယ်လင့်တကူဖတ်ရှုနိုင်ပါတယ်။
11 | https://bit.ly/3Xb5xGc
12 | 13 | Web development နဲ့ပတ်သတ်တဲ့ playlists, videos များကိုလည်း Youtube မှာဝင်ရောက်ကြည့်ရှုနိုင်ပါတယ်။
14 | https://bit.ly/3xtURtI
15 | 16 | ကျေးဇူးတင်ပါတယ်ခင်ဗျာ။ 17 | -------------------------------------------------------------------------------- /SUMMARY.md: -------------------------------------------------------------------------------- 1 | # Table of contents 2 | 3 | * [SQL-101](README.md) 4 | * [Data & Database](data\&database.md) 5 | * [DBMS](dbms.md) 6 | * [Introduction to SQL](sql\_intro.md) 7 | * [Data Types in SQL](datatypes.md) 8 | * [Environment Setup](environment_setup.md) 9 | * Diving Into SQL Queries 10 | * [Query Introduction](diving_queries.md) 11 | * [Data Definition Language](ddl.md) 12 | * [Data Query Language](dql.md) 13 | * [Data Manipulation Language](dml.md) 14 | * Let's get our hands dirty 15 | * [Sorting & Filtering](sf.md) 16 | * [Logical & Comparison Operators](operators.md) 17 | * [Aggregations](aggregation.md) 18 | * [DATE & TIME](dnt.md) 19 | * Relationships 20 | * [Relationship](relationship.md) 21 | * [Joins](joins.md) 22 | * [Relationship in queries](rtq.md) 23 | * Optimizations and controls 24 | * [Indexing](index.md) 25 | * [Triggers](trigger.md) 26 | * [Transactions](transaction.md) 27 | * [Normalization](normalization.md) 28 | * [Entity Relationship Diagram](erd.md) 29 | * [Conclusion](conclusion.md) 30 | -------------------------------------------------------------------------------- /aggregation.md: -------------------------------------------------------------------------------- 1 | 2 | ## Aggregation 3 | 4 | Data တွေကိုစုပေါင်းပြီးတော့တွက်ချက်မှုတွေ၊ report ပုံစံမျိုးတွေထုတ်ပေးနိုင်ဖို့အတွက် SQL က Aggregations ဆိုတဲ့ functions တွေကို support လုပ်ပေးထားပါတယ်။ သဘောတရားကိုပိုနားလည်နိုင်ဖို့အတွက်အောက်က query တွေစမ်းရေးကြည့်ပြီး results တွေကိုကြည့်နိုင်ပါတယ်။ 5 | 6 | သုံးနေကျ `students` table ကိုပဲဆက်သုံးကြပါမယ်။ 7 | 8 | 9 | ### COUNT 10 | 11 | ထွက်လာမယ့် result set တစ်ခုရဲ့data rows တွေကိုတွက်ချင်တဲ့အချိန်မှာ COUNT ဆိုတဲ့ function ကိုသုံးနိုင်ပါတယ်။ 12 | 13 | ``` 14 | SELECT COUNT(*) AS TotalStudents 15 | FROM students; 16 | ``` 17 | 18 | ![ag1](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ag/ag1.png) 19 | 20 | --- 21 | COUNT(*) ဆိုပြီး `*` ကိုသုံးပြီးတော့အားလုံးးရဲ့ results ကိုယူပါမယ်။ 22 | `AS TotalStudents` ဆိုတာကတော့ `alias` ပေးလိုက်တာဖြစ်ပါတယ်။ `alias` ဆိုတာကတော့အသုံးပြု (ပြန်ခေါ်လို့ရမယ့်)နာမည်တစ်ခုပေးလိုက်တာလို့ဆိုနိုင်ပါတယ်။ လောလောဆယ်သိပ်နားမလည်လည်းရပါတယ်။ 23 | 24 | `alias` မပါဘဲတန်းသုံးလည်းရပါတယ်။ ထွက်လာတဲ့ column နာမည်နေရာမှာတော့ `alias` နာမည်မဟုတ်တော့ဘဲ `COUNT(*)` ဆိုပြီးတော့ဘဲပါလာပါမယ်။ ဒါကြောင့်ပြန်ခေါ်သုံးရလွယ်အောင် နားလည်ရလွယ်ကူတဲ့ `alias` နာမည်လေးတွေပေးပြီး query ရေးလေ့ရှိကြပါတယ်။ 25 | 26 | ![ag2](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ag/ag2.png) 27 | 28 | --- 29 | 30 | ### SUM 31 | 32 | ကိန်းဂဏန်းတွေရှိတဲ့ column တွေရဲ့တန်ဖိုးတွေကိုစုပြီးပေါင်းချင်တဲ့အချိန်မှာ `SUM` ကိုသုံးနိုင်ပါတယ်။ ဥပမာ `students` table ထဲက `age` column တွေအကုန်ပေါင်းချင်တယ်ဆိုပါစို့၊ အောက်ကလိုမျိုး `SUM` ကိုသုံးပြီးရေးနိုင်ပါတယ်။ 33 | ``` 34 | SELECT SUM(age) AS TotalAge 35 | FROM students; 36 | ``` 37 | 38 | ![ag3](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ag/ag3.png) 39 | 40 | --- 41 | 42 | ### AVG 43 | 44 | AVG ကတော့ `SUM`နဲ့ပုံစံတူပဲ၊ သို့ပေမယ့်ပေါင်းတာမဟုတ်ဘဲနဲ့ Average ကိုတွက်ပေးတာဖြစ်ပါတယ်။ `students` table ထဲက `age` column ရဲ့ average ကိုတွက်ကြည့်ရအောင်။ (ဥပမာဒီကျောင်းကကျောင်းသားတွေရဲ့ average age ကဘယ်လောက်လဲဆိုတာမျိုးတွက်တဲ့နေရာမျိုးမှာအသုံးဝင်ပါတယ်။) 45 | 46 | ``` 47 | SELECT AVG(age) AS AverageAge 48 | FROM students; 49 | ``` 50 | 51 | ![ag4](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ag/ag4.png) 52 | 53 | ### MIN 54 | `MIN` ကတော့အသေးဆုံးကိန်းဂဏန်းကိုဆွဲထုတ်ချင်တဲ့အချိန်မျိုးမှာသုံးပါတယ်။ `students` table ထဲကအသက်အငယ်ဆုံးကျောင်းသားကိုသိချင်တယ်ဆိုရင် ဒီလိုမျိုးထုတ်ကြည့်နိုင်ပါတယ်။ 55 | ``` 56 | SELECT MIN(age) AS YoungestAge 57 | FROM students; 58 | ``` 59 | ![ag5](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ag/ag5.png) 60 | 61 | --- 62 | 63 | ### MAX 64 | 65 | `MAX` ကတော့ `MIN` နဲ့ပြောင်းပြန်အကြီးဆုံးကိုဆွဲထုတ်တာဖြစ်ပါတယ်။ 66 | ``` 67 | SELECT MAX(age) AS OldestAge 68 | FROM students; 69 | ``` 70 | ![ag6](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ag/ag6.png) 71 | 72 | --- 73 | 74 | ### GROUP BY 75 | 76 | `GROUP BY` ကိုအရှေ့မှာတွေ့ပြီးသားဖြစ်မှာပါ။ ထပ်ဖော်ပြရတဲ့အကြောင်းရင်းက Aggregation function တွေသုံးပြီး query ဆွဲတဲ့အချိန်မှာ `GROUP BY` ကိုသုံးပြီး group လေးတွေခွဲပြီး data တွေကိုထုတ်ကြည့်လို့ရပါတယ်။ ဥပမာ `major` တစ်ခုချင်းစီမှာကျောင်းသားဘယ်နှစ်ယောက်ရှိလဲဆိုတာမျိုးသိချင်ရင် `GROUP BY` ကို Aggregation function တွေနဲ့ပေါင်းပြီးအောက်ကလိုသုံးနိုင်ပါတယ်။ 77 | 78 | ``` 79 | SELECT major, COUNT(*) AS NumberOfStudents 80 | FROM students 81 | GROUP BY major; 82 | ``` 83 | 84 | ![ag7](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ag/ag7.png) 85 | 86 | --- 87 | ### HAVING 88 | 89 | `HAVING` ကတော့ အရှေ့အပိုင်းတွေမှာဖော်ပြခဲ့တဲ့ `WHERE` နဲ့အတူတူပါပဲ။ Aggregation functions တွေမှာ `WHERE` ကိုအသုံးပြုလို့မရနိုင်တဲ့အတွက် `HAVING` ကိုသုံးခြင်းဖြစ်ပါတယ်။ အပေါ်က query ကိုပဲ `HAVING` နဲ့ filter ခံကြည့်ရအောင်။ `major` group ထဲကမှကျောင်းသားတစ်ယောက်အထက်ရှိတဲ့ `major` ကိုပဲလိုချင်တယ်ဆိုပါစို့။ 90 | 91 | ``` 92 | SELECT major, COUNT(*) AS NumberOfStudents 93 | FROM students 94 | GROUP BY major 95 | HAVING COUNT(*) > 1; 96 | ``` 97 | 98 | ![ag8](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ag/ag8.png) 99 | 100 | --- 101 | 102 | Aggregation functions တွေက real world မှာလည်းအသုံးဝင်တဲ့ functions တွေဖြစ်ပါတယ်။ သူ့ချည်းပဲဆိုမသိသာပေမယ့် `GROUP BY` တို့ `HAVING` တို့ခံပြီးသုံးမယ်ဆိုအရမ်း powerful ဖြစ်တဲ့အပြင် query ကများတဲ့အခါရေးရတာလဲ နည်းနည်း tricky ဖြစ်တတ်ပါတယ်။ အပေါ်ကကျနော့်နမူနာကို စုတုပြုပြီး မိမိဘာသာဆက်ပြီးလေ့ကျင့်ကြည့်ကြပါဦး။ 103 | -------------------------------------------------------------------------------- /assets/datetime_datatypes.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/datetime_datatypes.png -------------------------------------------------------------------------------- /assets/erd.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/erd.png -------------------------------------------------------------------------------- /assets/linux/linux1.PNG: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/linux/linux1.PNG -------------------------------------------------------------------------------- /assets/linux/linux2.PNG: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/linux/linux2.PNG -------------------------------------------------------------------------------- /assets/linux/linux3.PNG: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/linux/linux3.PNG -------------------------------------------------------------------------------- /assets/linux/linux4.PNG: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/linux/linux4.PNG -------------------------------------------------------------------------------- /assets/linux/linux5.PNG: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/linux/linux5.PNG -------------------------------------------------------------------------------- /assets/linux/linux6.PNG: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/linux/linux6.PNG -------------------------------------------------------------------------------- /assets/linux/linux7.PNG: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/linux/linux7.PNG -------------------------------------------------------------------------------- /assets/mac/mac1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/mac/mac1.png -------------------------------------------------------------------------------- /assets/mac/mac10.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/mac/mac10.png -------------------------------------------------------------------------------- /assets/mac/mac2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/mac/mac2.png -------------------------------------------------------------------------------- /assets/mac/mac3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/mac/mac3.png -------------------------------------------------------------------------------- /assets/mac/mac4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/mac/mac4.png -------------------------------------------------------------------------------- /assets/mac/mac5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/mac/mac5.png -------------------------------------------------------------------------------- /assets/mac/mac6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/mac/mac6.png -------------------------------------------------------------------------------- /assets/mac/mac7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/mac/mac7.png -------------------------------------------------------------------------------- /assets/mac/mac8.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/mac/mac8.png -------------------------------------------------------------------------------- /assets/mac/mac9.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/mac/mac9.png -------------------------------------------------------------------------------- /assets/numeric_datatypes.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/numeric_datatypes.png -------------------------------------------------------------------------------- /assets/queries/ag/ag1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ag/ag1.png -------------------------------------------------------------------------------- /assets/queries/ag/ag2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ag/ag2.png -------------------------------------------------------------------------------- /assets/queries/ag/ag3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ag/ag3.png -------------------------------------------------------------------------------- /assets/queries/ag/ag4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ag/ag4.png -------------------------------------------------------------------------------- /assets/queries/ag/ag5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ag/ag5.png -------------------------------------------------------------------------------- /assets/queries/ag/ag6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ag/ag6.png -------------------------------------------------------------------------------- /assets/queries/ag/ag7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ag/ag7.png -------------------------------------------------------------------------------- /assets/queries/ag/ag8.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ag/ag8.png -------------------------------------------------------------------------------- /assets/queries/ddl/ddl1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ddl/ddl1.png -------------------------------------------------------------------------------- /assets/queries/ddl/ddl10.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ddl/ddl10.png -------------------------------------------------------------------------------- /assets/queries/ddl/ddl11.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ddl/ddl11.png -------------------------------------------------------------------------------- /assets/queries/ddl/ddl12.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ddl/ddl12.png -------------------------------------------------------------------------------- /assets/queries/ddl/ddl2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ddl/ddl2.png -------------------------------------------------------------------------------- /assets/queries/ddl/ddl3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ddl/ddl3.png -------------------------------------------------------------------------------- /assets/queries/ddl/ddl4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ddl/ddl4.png -------------------------------------------------------------------------------- /assets/queries/ddl/ddl5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ddl/ddl5.png -------------------------------------------------------------------------------- /assets/queries/ddl/ddl6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ddl/ddl6.png -------------------------------------------------------------------------------- /assets/queries/ddl/ddl7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ddl/ddl7.png -------------------------------------------------------------------------------- /assets/queries/ddl/ddl8.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ddl/ddl8.png -------------------------------------------------------------------------------- /assets/queries/ddl/ddl9.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ddl/ddl9.png -------------------------------------------------------------------------------- /assets/queries/dml/dml1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dml/dml1.png -------------------------------------------------------------------------------- /assets/queries/dml/dml2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dml/dml2.png -------------------------------------------------------------------------------- /assets/queries/dml/dml3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dml/dml3.png -------------------------------------------------------------------------------- /assets/queries/dml/dml4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dml/dml4.png -------------------------------------------------------------------------------- /assets/queries/dml/dml5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dml/dml5.png -------------------------------------------------------------------------------- /assets/queries/dml/dml6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dml/dml6.png -------------------------------------------------------------------------------- /assets/queries/dml/dml7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dml/dml7.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt1.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt10.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt10.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt11.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt11.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt12.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt12.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt13.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt13.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt14.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt14.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt2.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt3.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt4.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt5.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt6.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt7.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt8.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt8.png -------------------------------------------------------------------------------- /assets/queries/dnt/dnt9.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dnt/dnt9.png -------------------------------------------------------------------------------- /assets/queries/dql/dql1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dql/dql1.png -------------------------------------------------------------------------------- /assets/queries/dql/dql10.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dql/dql10.png -------------------------------------------------------------------------------- /assets/queries/dql/dql11.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dql/dql11.png -------------------------------------------------------------------------------- /assets/queries/dql/dql12.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dql/dql12.png -------------------------------------------------------------------------------- /assets/queries/dql/dql2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dql/dql2.png -------------------------------------------------------------------------------- /assets/queries/dql/dql3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dql/dql3.png -------------------------------------------------------------------------------- /assets/queries/dql/dql4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dql/dql4.png -------------------------------------------------------------------------------- /assets/queries/dql/dql5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dql/dql5.png -------------------------------------------------------------------------------- /assets/queries/dql/dql6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dql/dql6.png -------------------------------------------------------------------------------- /assets/queries/dql/dql7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dql/dql7.png -------------------------------------------------------------------------------- /assets/queries/dql/dql8.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dql/dql8.png -------------------------------------------------------------------------------- /assets/queries/dql/dql9.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/dql/dql9.png -------------------------------------------------------------------------------- /assets/queries/ds1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ds1.png -------------------------------------------------------------------------------- /assets/queries/ds10.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ds10.png -------------------------------------------------------------------------------- /assets/queries/ds11.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ds11.png -------------------------------------------------------------------------------- /assets/queries/ds12.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ds12.png -------------------------------------------------------------------------------- /assets/queries/ds2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ds2.png -------------------------------------------------------------------------------- /assets/queries/ds3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ds3.png -------------------------------------------------------------------------------- /assets/queries/ds4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ds4.png -------------------------------------------------------------------------------- /assets/queries/ds5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ds5.png -------------------------------------------------------------------------------- /assets/queries/ds6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ds6.png -------------------------------------------------------------------------------- /assets/queries/ds7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ds7.png -------------------------------------------------------------------------------- /assets/queries/ds8.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ds8.png -------------------------------------------------------------------------------- /assets/queries/ds9.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/ds9.png -------------------------------------------------------------------------------- /assets/queries/index/index1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/index/index1.png -------------------------------------------------------------------------------- /assets/queries/index/index2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/index/index2.png -------------------------------------------------------------------------------- /assets/queries/index/index3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/index/index3.png -------------------------------------------------------------------------------- /assets/queries/index/index4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/index/index4.png -------------------------------------------------------------------------------- /assets/queries/index/index5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/index/index5.png -------------------------------------------------------------------------------- /assets/queries/index/index6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/index/index6.png -------------------------------------------------------------------------------- /assets/queries/index/index7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/index/index7.png -------------------------------------------------------------------------------- /assets/queries/join/j1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/join/j1.png -------------------------------------------------------------------------------- /assets/queries/join/j2.1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/join/j2.1.png -------------------------------------------------------------------------------- /assets/queries/join/j2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/join/j2.png -------------------------------------------------------------------------------- /assets/queries/join/j3.1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/join/j3.1.png -------------------------------------------------------------------------------- /assets/queries/join/j3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/join/j3.png -------------------------------------------------------------------------------- /assets/queries/join/j4.1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/join/j4.1.png -------------------------------------------------------------------------------- /assets/queries/join/j4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/join/j4.png -------------------------------------------------------------------------------- /assets/queries/join/j5.1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/join/j5.1.png -------------------------------------------------------------------------------- /assets/queries/join/j5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/join/j5.png -------------------------------------------------------------------------------- /assets/queries/nor/nor1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/nor/nor1.png -------------------------------------------------------------------------------- /assets/queries/nor/nor2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/nor/nor2.png -------------------------------------------------------------------------------- /assets/queries/op/op1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/op/op1.png -------------------------------------------------------------------------------- /assets/queries/op/op2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/op/op2.png -------------------------------------------------------------------------------- /assets/queries/op/op3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/op/op3.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq1.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq10.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq10.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq11.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq11.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq12.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq12.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq13.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq13.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq14.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq14.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq2.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq3.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq4.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq5.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq6.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq7.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq8.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq8.png -------------------------------------------------------------------------------- /assets/queries/rtq/rtq9.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/rtq/rtq9.png -------------------------------------------------------------------------------- /assets/queries/sf/sf1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/sf/sf1.png -------------------------------------------------------------------------------- /assets/queries/sf/sf10.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/sf/sf10.png -------------------------------------------------------------------------------- /assets/queries/sf/sf11.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/sf/sf11.png -------------------------------------------------------------------------------- /assets/queries/sf/sf12.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/sf/sf12.png -------------------------------------------------------------------------------- /assets/queries/sf/sf2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/sf/sf2.png -------------------------------------------------------------------------------- /assets/queries/sf/sf3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/sf/sf3.png -------------------------------------------------------------------------------- /assets/queries/sf/sf4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/sf/sf4.png -------------------------------------------------------------------------------- /assets/queries/sf/sf5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/sf/sf5.png -------------------------------------------------------------------------------- /assets/queries/sf/sf6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/sf/sf6.png -------------------------------------------------------------------------------- /assets/queries/sf/sf7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/sf/sf7.png -------------------------------------------------------------------------------- /assets/queries/sf/sf8.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/sf/sf8.png -------------------------------------------------------------------------------- /assets/queries/sf/sf9.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/sf/sf9.png -------------------------------------------------------------------------------- /assets/queries/tran/tr1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/tran/tr1.png -------------------------------------------------------------------------------- /assets/queries/tran/tr2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/tran/tr2.png -------------------------------------------------------------------------------- /assets/queries/tran/tr3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/tran/tr3.png -------------------------------------------------------------------------------- /assets/queries/tran/tr4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/tran/tr4.png -------------------------------------------------------------------------------- /assets/queries/tran/tr5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/tran/tr5.png -------------------------------------------------------------------------------- /assets/queries/tran/tr6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/tran/tr6.png -------------------------------------------------------------------------------- /assets/queries/tran/tr7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/tran/tr7.png -------------------------------------------------------------------------------- /assets/queries/tran/tr8.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/tran/tr8.png -------------------------------------------------------------------------------- /assets/queries/tri/tr1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/tri/tr1.png -------------------------------------------------------------------------------- /assets/queries/tri/tr2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/queries/tri/tr2.png -------------------------------------------------------------------------------- /assets/string_datatypes.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/string_datatypes.png -------------------------------------------------------------------------------- /assets/win/window1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window1.png -------------------------------------------------------------------------------- /assets/win/window10.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window10.png -------------------------------------------------------------------------------- /assets/win/window11.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window11.png -------------------------------------------------------------------------------- /assets/win/window12.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window12.png -------------------------------------------------------------------------------- /assets/win/window13.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window13.png -------------------------------------------------------------------------------- /assets/win/window14.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window14.png -------------------------------------------------------------------------------- /assets/win/window15.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window15.png -------------------------------------------------------------------------------- /assets/win/window16.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window16.png -------------------------------------------------------------------------------- /assets/win/window17.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window17.png -------------------------------------------------------------------------------- /assets/win/window18.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window18.png -------------------------------------------------------------------------------- /assets/win/window19.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window19.png -------------------------------------------------------------------------------- /assets/win/window2.PNG: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window2.PNG -------------------------------------------------------------------------------- /assets/win/window20.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window20.png -------------------------------------------------------------------------------- /assets/win/window21.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window21.png -------------------------------------------------------------------------------- /assets/win/window22.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window22.png -------------------------------------------------------------------------------- /assets/win/window23.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window23.png -------------------------------------------------------------------------------- /assets/win/window3.PNG: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window3.PNG -------------------------------------------------------------------------------- /assets/win/window4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window4.png -------------------------------------------------------------------------------- /assets/win/window5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window5.png -------------------------------------------------------------------------------- /assets/win/window6.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window6.png -------------------------------------------------------------------------------- /assets/win/window7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window7.png -------------------------------------------------------------------------------- /assets/win/window8.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window8.png -------------------------------------------------------------------------------- /assets/win/window9.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/501fb1d9e63e540093ae994392b57781affd3c10/assets/win/window9.png -------------------------------------------------------------------------------- /conclusion.md: -------------------------------------------------------------------------------- 1 | ## Conclusion 2 | 3 | SQL ကိုလေ့လာချင်တဲ့ beginners တွေအတွက်ရည်ရွယ်ပြီး သင့်တော်မယ့်ကောင်းနိုးရာရာအပိုင်းတွေကိုထုတ်နုတ်ပြီး series လေးလုပ်ထားလိုက်တာဖြစ်ပါတယ်။
4 | 5 | series ထဲမှာမပါနိုင်တဲ့တစ်ခြားသောအကြောင်းအရာတွေများစွာရှိသေးအတွက် ဒီနေရာကနေလမ်းစတစ်ခုရပြီး ရှေ့ဆက်လေ့လာသွားဖို့အထောက်အကူပြုနိုင်မယ်လို့ မျှော်လင့်ပါတယ်။
6 | 7 | ကျေးဇူးတင်ပါတယ်ခင်ဗျာ။
8 | 9 | June 8 2024 22:09:30
10 | Hlaing Tin Htun 11 | -------------------------------------------------------------------------------- /data&database.md: -------------------------------------------------------------------------------- 1 | # Data & Database 2 | 3 | SQL 101 series ရဲ့ပထမဦးဆုံးအပိုင်းဖြစ်ပါတယ်။ 4 | 5 | ဒီအပိုင်းမှာတော့ data နဲ့ database အကြောင်းကို intro ဝင်ပေးသွားပါမယ်။ 6 | 7 | ဒေတာ(data) ဆိုတဲ့ စကားလုံးကိုကျနော်တို့အားလုံးမစိမ်းလောက်ပါဘူး။ ကျနော့်တို့ကိုယ်တိုင်ကစလို့ နေရာတိုင်းမှာ data တွေရှိတယ်။ ဘယ်လိုအရာတွေကို data လို့ခေါ်နိုင်လဲဆိုရင် အချက်အလက်တစ်ခုက ကောက်ယူလို့ရမယ်၊ သိမ်းဆည်းလို့ရမယ်၊ အသုံးပြုလို့ရမယ်ဆိုရင် data လို့သတ်မှတ်နိုင်ပါတယ်။ ဥပမာဖုန်းထဲကဓါတ်ပုံ၊ဗီဒီယိုတွေ၊ ရာသီဥတုအချက်အလက်တွေ၊ စတော့ဈေးနှုန်းတွေစသည်ဖြင့် ဒါတွေအားလုံးက data တွေပဲဖြစ်ပါတယ်။ ယနေ့ခေတ်မှာ data တွေက အလွန်တန်ဖိုးရှိလာပါတယ်။ ဒါကြောင့်လည်း data တွေအများကြီးပိုင်ဆိုင်ထားတဲ့ google, facebook တို့လို companies တွေဟာတန်ဖိုးကြီးနေရခြင်းဖြစ်ပါတယ်။ 8 | 9 | နေ့စဉ်နဲ့အမျှနေရာပေါင်းစုံကနေ data တွေထွက်နေနိုင်ပါတယ်။ သို့ပေမယ့် ဒီ data တွေကိုသိမ်းဆည်းခြင်းမရှိဘူးဆိုရင် ပြန်လည်အသုံးပြုလို့မရနိုင်တဲ့အတွက် အကျိုးမရှိနိုင်ပါဘူး။ သိမ်းဆည်းဖို့နည်းလမ်းတစ်ခုလိုအပ်တဲ့အတွက် database ဆိုတဲ့အရာကို အသုံးပြုပါတယ်။ database ထဲမှာ data တွေသိမ်းဆည်းခြင်း၊ ပြန်လည်ထုတ်ယူသုံးစွဲခြင်းစသည်ဖြင့်ပြုလုပ်ကြပါတယ်။ 10 | 11 | Database ဆိုလို့အသစ်အဆန်းတစ်ခုတော့မဟုတ်ဘူး၊ computer တစ်လုံးသက်သက်ပါပဲ။ hardware နဲ့ software ပေါင်းစပ်ပြီး data တွေသိမ်းဆည်းတာတွေ၊ အသုံးပြုတာတွေပြုလုပ်နိုင်ပါတယ်။ နောက်လာမယ့်အပိုင်းတွေမှာ computer ထဲကို လိုအပ်တဲ့ software installation လုပ်ပြီးတော့ စတင်လေ့လာကြပါမယ်။ 12 | -------------------------------------------------------------------------------- /datatypes.md: -------------------------------------------------------------------------------- 1 | # Data Types in SQL 2 | 3 | ဒီအပိုင်းမှာတော့ SQL မှာရှိတဲ့ data types တွေအကြောင်းကိုဆွေးနွေးသွားပြီးတော့ နောက်အပိုင်းကနေစပြီးတော့ environment setup (လိုအပ်တဲ့ software တွေသွင်း) လုပ်မယ်၊ လက်တွေ့ query တွေရေးပြီးတော့ ဆက်လက်လေ့လာသွားကြပါမယ်။ 4 | 5 | အရှေ့မှာ SQL ရဲ့ table, row, column တွေအကြောင်းကိုအဓိပ္ပါယ်ဖွင့်ဆိုခဲ့ပါတယ်။ Column တစ်ခုမှာ data သိမ်းတော့မယ်ဆို သိမ်းချင်တဲ့ data ရဲ့ပုံစံကိုပါထည့်သွင်းဖော်ပြပေးရပါတယ်။ ဥပမာမြင်သာအောင်ပြောရရင် programmers ဆိုတဲ့ programmer တွေရဲ့ data ကိုသိမ်းမယ့် table တစ်ခုရှိတယ်ဆိုပါစို့။ name, email, gender, age ဆိုတဲ့ column လေးခုသိမ်းဆည်းကြပါမယ်။ 6 | 7 | * name ကို စာသား 8 | * email ကိုလည်းစာသား 9 | * gender ကိုလည်းစာသားသိမ်းမယ်၊ Male, Female 10 | * ဒါမှမဟုတ် ကိန်းကဏန်းအနေနဲ့ 1,2 နဲ့သိမ်းလည်းရတာပဲ၊ 1 က male, 2 က female 11 | * age ကိုတော့ ကိန်းကဏန်းအနေနဲ့သိမ်းမယ်။ 20, 30 စသည်ဖြင့်ပေါ့။ 12 | 13 | ဘာလို့ဒီလိုတွေခွဲပြီးသိမ်းနေရတာလဲ၊ တစ်မျိုးတည်းသတ်မှတ်ပြီးသိမ်းလည်းရတာပဲမဟုတ်လားလို့မေးစရာရှိပါတယ်။ ဘာကြောင့် data types တွေခွဲသိမ်းဖို့လိုတယ်၊ အရေးကြီးတယ်ဆိုတာကို ဒီ article conclude လုပ်တဲ့အချိန်မှာ ထည့်ရေးပေးသွားပါမယ်။ 14 | 15 | လောလောဆယ်ဘယ်လိုမျိုး data types တွေရှိတယ်ဆိုတာကြည့်ရအောင်။ ဒီ article မှာတော့ common data types အသုံးများတဲ့ data types တွေအကြောင်းကိုထည့်ပေးသွားပါမယ်။ data types တွေကအများကြီးရှိတဲ့အပြင် အရှေ့မှာပြောခဲ့တဲ့ DBMS software တွေပေါ်မူတည်ပြီးတော့လည်းအမျိုးမျိုးကွဲပြားနိုင်သေးတယ်။ သို့သော် အခုရေးထားတဲ့ data types တွေနားလည်ထားမယ်ဆို စတင်လေ့လာတဲ့သူတစ်ယောက်အနေနဲ့ လုံလောက်မယ်လို့ယူဆပါတယ်။ 16 | 17 | * Numeric data type - ကိန်းကဏန်းတွေသိမ်းဆည်းရန် 18 | * Character data type - စာသားတွေသိမ်းဆည်းရန် 19 | * Date & Time data type - နေ့ရက်နှင့်အချိန်ကာလတွေသိမ်းဆည်းရန် 20 | 21 | တစ်ခုခြင်းဆီကိုအသေးစိတ်ပြန်ကြည့်ရရင် 22 | 23 | ## Numeric Data Types 24 | 25 | * TINYINT – 1-byte size ကိန်းကဏန်းတွေသိမ်းဆည်းရန် 26 | * SMALLINT – 2-byte size ကိန်းကဏန်းတွေသိမ်းဆည်းရန် 27 | * INT – 4-byte size ကိန်းကဏန်းတွေသိမ်းဆည်းရန် 28 | * BIGINT – 8-byte size ကိန်းကဏန်းတွေသိမ်းဆည်းရန် 29 | * DECIMAL – precise ဖြစ်တဲ့၊တိကျသေချာတဲ့ ဒဿမကိန်းကဏန်းတွေသိမ်းဆည်းရန် 30 | * FLOAT – approximate ဖြစ်တဲ့၊ မှန်းခြေ ဒဿမကိန်းကဏန်းတွေသိမ်းဆည်းရန် 31 | * DOUBLE – FLOAT ထက်ပို precise ဖြစ်၊ range များများလိုတဲ့အချိန်မှာ DOUBLE ကိုသုံးပါတယ်။ 32 | * BOOLEAN – TRUE/FALSE တန်ဖိုးနှစ်ခုထဲသာရှိတဲ့ Logical value သိမ်းဆည်းရန် 33 | 34 | ## Character Data Types 35 | 36 | * CHAR – fixed-length ဖြစ်တဲ့စာသားတွေသိမ်းဆည်းရန်။ 37 | * VARCHAR – maximum length ကို define လုပ်ပြီးသိမ်းဆည်းနိုင်ပါတယ်။ 38 | * TEXT – သိမ်းဆည်းရမယ့် စာသားကိုများတယ်ဆို TEXT ကိုအသုံးပြုနိုင်ပါတယ်။ MEDIUMTEXT, LONGTEXT အစရှိတာတွေကိုအသုံးပြုနိုင်ပါတယ်။ 39 | 40 | ## Date & Time Data Types 41 | 42 | * Date – YYYY-MM-DD format နဲ့ Year, Month, Date တန်ဖိုးတွေသိမ်းဆည်းရန် 43 | * Time – HH:MM:SS format နဲ့ နာရီ၊မိနစ်၊ စက္ကန့် တန်ဖိုးတွေသိမ်းဆည်းရန် 44 | * DATETIME/TIMESTAMP – Date နဲ့ Time ကိုပေါင်းစည်းပြီးသိမ်းဖို့လိုတဲ့အချိန်တွေအသုံးပြုရန် 45 | 46 | အခုအပေါ်မှာပြောခဲ့တာတွေကတော့ အသုံးပြုတာများတဲ့ data types တွေပဲဖြစ်ပါတယ်။ storage size တွေကိုတော့ ကျနော်လည်းအလွတ်မရပါဘူး၊ လိုအပ်တဲ့အချိန်မှသာသက်ဆိုင်ရာ documentation ကိုပြေးကြည့်လိုက်တာပဲ။ W3Schools မှာတော့ data types တွေကိုဒီလိုပိုမိုတိတိကျကျဖော်ပြထားပါတယ်။ Reference အနေနဲ့ထည့်သွင်းဖော်ပြပေးလိုက်ပါတယ်။ MySQL Data Types (Version 8.0) အတွက်ဖြစ်ပါတယ်။ (DBMS အလိုက်ပြောင်းလဲနိုင်တာကြောင့် အသုံးပြုတဲ့ DBMS နဲ့ version ကိုပူးတွဲဖော်ပြခြင်းဖြစ်ပါတယ်) 47 | 48 | ![Numeric DataTypes](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/numeric\_datatypes.png) ![String DataTypes](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/string\_datatypes.png) ![DateTime DataTypes](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/datetime\_datatypes.png) 49 | 50 | [https://www.w3schools.com/sql/sql\_datatypes.asp](https://www.w3schools.com/sql/sql\_datatypes.asp) 51 | 52 | ဒီ URL ကနေတစ်ဆင့်လည်းသွားရောက်ဖတ်ရှုနိုင်ပါတယ်။ 53 | 54 | ## Why Data Types? 55 | 56 | ဘာလို့ data types တွေကအရေးကြီးတာလဲဆိုတော့ 57 | 58 | ### Data Integrity 59 | 60 | Product description သိမ်းဆည်းရမယ့်နေရာမှာ TEXT လိုမျိုး data type သုံးခြင်းအားဖြင့် description text data တွေပြတ်တောက်ခြင်းမရှိဘဲခိုင်မာမှုကောင်းကောင်းနဲ့သိမ်းဆည်းနိုင်ပါတယ်။ ဥပမာ Varchar ကို size 20 လောက်သတ်မှတ်ပြီးသိမ်းလိုက်မယ်ဆို data ဖြတ်ချခံရနိုင်တဲ့ဖြစ်နိုင်ချေရှိပါတယ်။ 61 | 62 | ### Storage Optimization 63 | 64 | Data ကိုလိုသလောက်ပဲ data type တွေခွဲခြားသတ်မှတ်ပေးခြင်းအားဖြင့် data storage ပမာဏကိုလျော့ချနိုင်ပါတယ်။ ဥပမာ ဒီ row ကဖျက်ထားလားဆိုတဲ့ is\_deleted ဆိုတဲ့ column လိုမျိုးကို BOOLEAN လို value ကိုသုံးသင့်ပါတယ်။ INT တို့ MEDIUMINT တို့သုံးလိုက်မယ်ဆို မလိုအပ်ဘဲ storage ပမာဏပိုပေးရပါတယ်။ 65 | 66 | ### Query Optimization 67 | 68 | Data တွေကို filter, sort လုပ်ဖို့အတွက် data type တွေခွဲထားမှသာအဆင်ပြေပါမယ်။ ဥပမာ monthly data ဆွဲမယ်ဆို column ကို DATE data type နဲ့သိမ်းထားမှသာ query ကိုကောင်းမွန်စွာ ဆွဲနိုင်မှာဖြစ်ပါတယ်။ 69 | 70 | ### Calculation 71 | 72 | အတွက်အချက်နဲ့ပတ်သတ်တဲ့ query တွေ run ဖို့လိုအပ်လာချိန်မှာလည်း သင့်တော်တဲ့ data type တွေခွဲထားမှသာ calculation ကောင်းကောင်းလုပ်နိုင်မှာဖြစ်ပါတယ်။ ဥပမာ INT သိမ်းရမယ့် column လိုနေရာမျိုးမှာ TEXT နဲ့သိမ်းထားမယ်ဆို calculation လုပ်တဲ့နေရာမှာအခက်အခဲတွေရှိနိုင်ပါတယ်။ 73 | -------------------------------------------------------------------------------- /dbms.md: -------------------------------------------------------------------------------- 1 | # DBMS 2 | 3 | သိမ်းဆည်းထားတဲ့ data တွေကို manage လုပ်ဖို့အတွက်ဆိုရင် DBMS ဆိုတဲ့အရာတွေကလိုအပ်လာပါတယ်။ 4 | 5 | DBMS အကြောင်းကိုရေးရင်းနဲ့တစ်လက်စတည်း database models အကြောင်းနဲ့ RDBMS အကြောင်းကိုရေးပေးသွားပါမယ်။ 6 | 7 | DBMS ဆိုတာက software တစ်ခုပါပဲ။ အဲ့ဒီ software ကိုအသုံးပြုပြီးတော့ database ထဲမှာရှိတဲ့ data တွေကို ထုတ်ယူ၊သိမ်းဆည်း၊ပြုပြင်တာတွေကိုလုပ်ဆောင်နိုင်ပါတယ်။ 8 | ပြောရမယ်ဆိုရင် အသုံးပြုသူနဲ့ database နှစ်ခုကြားထဲမှာ data တွေကို manipulate လုပ်ဖို့ interface တစ်ခုအနေနဲ့တည်ရှိနေပါတယ်။ 9 | User -> DBMS -> Database ပုံစံမျိုးပေါ့။ အသုံးပြုသူကနေတစ်ဆင့် လိုသလို data တွေကို manage လုပ်နိုင်ဖို့အတွက် DMBS ကို inputs (queries) တွေပေးဖို့လိုပါသေးတယ်။ 10 | ဒီအပိုင်းကိုတော့နောက်အပိုင်းတွေမှာထပ်ရေးသွားပါမယ်။ 11 | 12 | DBMS တွေကအမျိုးမျိုးရှိတယ်၊ ရွေးချယ်ထားတဲ့ database models ပေါ်မူတည်ပြီးတော့ DBMS ပုံစံတွေကလည်းကွဲပြားတယ်။ Database model ဆိုတာကတော့ database system တစ်ခုမှာ data တွေကိုဘယ်လို structure တွေနဲ့သိမ်းဆည်းမယ်၊ ချိတ်ဆက်မယ်ဆိုတာတွေကိုသတ်မှတ်ထားတဲ့ ပုံစံဖြစ်ပါတယ်။ ဥပမာ Model A ဆိုရင် Excel ထဲမှာ rows တွေ column တွေနဲ့မှတ်ပြီးသိမ်းမယ်၊ Model B ဆိုရင် Notepad ထဲမှာပဲ key value pair ပုံစံတွေနဲ့သိမ်းမယ် စသည်ဖြင့် model ပေါ်မူတည်ပြီး data တွေကိုစီမံခန့်ခွဲပုံကလည်း ကွဲပြောင်းသွားပါတယ်။ 13 | Database Models တွေအများကြီးထဲကမှအသုံးများတဲ့ models တွေကို list down လုပ်ပေးထားလိုက်ပါမယ်။ 14 | 15 | - Relational Model 16 | - Hierarchical Model 17 | - Network Model 18 | - Object-Oriented Model 19 | - Document Model 20 | - Graph Model 21 | စသည်ဖြင့်ရှိကြပါတယ်။ DB Engines ranking ဆိုပြီးရိုက်ရှာကြည့်လိုက်မယ်ဆိုရင်လည်းအသုံးများတဲ့ model တွေကိုတွေ့နိုင်ပါတယ်။ 22 | 23 | https://db-engines.com/en/ranking 24 | 25 | ဒီ article series မှာကတော့ Structure Query Language (SQL) ကိုအသုံးပြုတဲ့ Relational Model အကြောင်းကိုပဲလေ့လာသွားကြပါမယ်။ 26 | Relational model ကိုအသုံးပြုတဲ့ RDBMS မှာလည်း provider ပေါ်မူတည်ပြီးတော့ DBMS software တွေကအနည်းနဲ့အများကွဲပြားသွားနိုင်ပါသေးတယ်။ 27 | သို့ပေမယ့် SQL oriented approach နဲ့သွားတာဖြစ်တဲ့အတွက်အများကြီးပြောင်းလဲသွားတာတော့မရှိပါဘူး။ 28 | ဥပမာ 29 | - Oracle Database 30 | - MySQL 31 | - PostgreSQL 32 | - Microsoft SQL Server 33 | စသည်ဖြင့်ပေါ့။ အားလုံးက RDBMS ဖြစ်ပေမယ့် company ပေါ်မူတည်ပြီးအသုံးပြုပုံအနည်းငယ်ကွာဟသွားနိုင်ပါတယ်။ 34 | 35 | Relational Model တွေက data တွေကိုဘယ်လိုသိမ်းဆည်းလဲဆိုတာနဲ့ပြန်ဆက်ရအောင်။ 36 | 37 | သူတို့က data တွေကို table ပုံစံ၊ row , column နှစ်ခုပါတဲ့ two dimensional structures နဲ့သိမ်းဆည်းပါတယ်။ 38 | table တစ်လုံးခြင်းဆီတိုင်းမှာ rows (records) , columns (fields) ပုံစံတွေနဲ့သက်ဆိုင်ရာ data တွေကိုထည့်သွင်းသိမ်းဆည်းပါတယ်။ 39 | row (record) တစ်ခုခြင်းဆီတိုင်းကို unique ဖြစ်စေဖို့ (row အချင်းချင်း duplicate/conflict) မဖြစ်စေရန် primary key သတ်မှတ်ပေးပြီးတော့ table တစ်လုံးက field တစ်ခုကနေပြီးတော့ နောက် table တစ်လုံးက primary key ကိုလှမ်း reference လုပ်ချင်တဲ့အချိန်မှာ foreign key အဖြစ်သတ်မှတ်တာမျိုးတွေလည်းရှိပါတယ်။ 40 | 41 | လောလောဆယ်တော့နည်းနည်းရှုပ်နေနိုင်သေးပေမယ့် နောက်လာမယ့်အပိုင်းတွေမှာ query တွေရေးကြည့်တဲ့အခါလွယ်ကူသွားပါလိမ့်မယ်။ 42 | -------------------------------------------------------------------------------- /ddl.md: -------------------------------------------------------------------------------- 1 | # Data Definition Language (DDL) 2 | 3 | Data Definition လို့ဆိုတဲ့အတိုင်း DDL သည် database ရဲ့ structure တွေကိုသတ်မှတ်တည်ဆောက်ခြင်း၊ ပြောင်းလဲခြင်းတွေပြုလုပ်တဲ့ query တွေအတွက်သတ်မှတ်ထားတဲ့ category ဖြစ်ပါတယ်။ 4 | Database တစ်ခုတည်ဆောက်တဲ့နေရာမှာအရေးပါတဲ့ table, column data structure တွေကိုစီမံခန့်ခွဲခြင်း၊ data integrity ကောင်းရန်အတွက် အခြားသောလိုအပ်တဲ့ စည်းမျဉ်းများကို define လုပ်ရန်အတွက်အသုံးပြုပါတယ်။ 5 | data integrity ကိုအဓိပ္ပါယ်ရှိပြီးမှန်ကန်တဲ့ dataတွေလို့အကြမ်းဖျင်းသတ်မှတ်နိုင်ပါတယ်။ 6 | 7 | DDL ကိုဝါကျတစ်ကြောင်းတည်းနဲ့နားလည်အောင်ပြောရမယ်ဆို Database တစ်ခုရုပ်လုံးပေါ်လာအောင် structure တွေသတ်မှတ်(define) လုပ်ပေးရတဲ့ query များဆိုပြီးပြောနိုင်မယ်ထင်တယ်။ 8 | ဒီအပိုင်းမှာတော့အရေးကြီးပြီးအသုံးများတဲ့ DDL queries တွေကိုလေ့လာသွားကြပါမယ်။ 9 | 10 | ## CREATE DATABASE: Defining a New Database 11 | စမ်းချင်တာတွေစမ်းဖို့အတွက် `ddl_test` ဆိုတဲ့ database တစ်လုံးအရင်တည်ဆောက်လိုက်ရအောင်။ 12 | 13 | ``` 14 | CREATE DATABASE ddl_test; 15 | ``` 16 | 17 | ![creating db](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ddl/ddl1.png) 18 | 19 | ## CREATE TABLE: Defining a New Table 20 | အရှေ့အပိုင်းမှာကျနော်တို့တွေ့ခဲ့ပြီးသားဖြစ်ပါတယ်။ database ထဲမှာ table တစ်လုံးတည်ဆောက်ရန်အတွက်အသုံးပြုပါတယ်။ လိုအပ်တဲ့ column နာမည်၊ structure တို့ကို define လုပ်ပြီးတည်ဆောက်နိုင်ပါတယ်။ 21 | 22 | #### Schema: 23 | ``` 24 | CREATE TABLE table_name ( 25 | column_name data_type, 26 | ..., 27 | constraint_definition 28 | ); 29 | ``` 30 | 31 | Students ဆိုတဲ့ table တစ်လုံးတည်ဆောက်ရအောင်။ 32 | 33 | #### Query 34 | ``` 35 | CREATE TABLE students( 36 | student_id INT, 37 | name VARCHAR(50), 38 | age INT, 39 | remark VARCHAR (50) 40 | ); 41 | ``` 42 | 43 | `SHOW TABLES;` နဲ့ပြန်ပြီးစစ်ကြည့်နိုင်ပါတယ်။ 44 | 45 | ![creating table](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ddl/ddl2.png) 46 | 47 | ## ALTER TABLE: Modifying Table Structure 48 | 49 | ရှိပြီးသား table ရဲ့ structure ကိုပြောင်းလဲ `ALTER TABLE` ဆိုတဲ့ command ကိုအသုံးပြုပါတယ်။ 50 | table ထဲကို column အသစ်ထည့်တာ၊ ရှိပြီးသား column name ကိုပြောင်းတာ၊ column ကိုဖျက်တာစသည်ဖြင့်လုပ်ဆောင်နိုင်ပါတယ်။ 51 | 52 | ### Adding a new column (column အသစ်ထည့်ခြင်း) 53 | 54 | #### Schema 55 | ``` 56 | ALTER TABLE table_name 57 | ADD column_name data_type constraint_definition, 58 | ...; 59 | ``` 60 | #### Query 61 | ``` 62 | ALTER TABLE students 63 | ADD nick_name VARCHAR(50); 64 | ```` 65 | 66 | `DESCRIBE` keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။ 67 | 68 | ![alter_col_add](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ddl/ddl3.png) 69 | 70 | ### Changing column name (column အမည်ပြောင်းခြင်း) 71 | 72 | #### Schema 73 | ``` 74 | ALTER TABLE table_name 75 | RENAME COLUMN old_column_name TO new_column_name; 76 | ``` 77 | 78 | #### Query 79 | 80 | ``` 81 | ALTER TABLE students 82 | RENAME COLUMN name TO formal_name; 83 | ``` 84 | 85 | `DESCRIBE` keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။ 86 | 87 | ![alter_col_rm](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ddl/ddl4.png) 88 | 89 | ### Dropping a column (column ဖျက်ခြင်း) 90 | 91 | #### Schema 92 | ``` 93 | ALTER TABLE table_name 94 | DROP COLUMN column_name; 95 | ``` 96 | 97 | #### Query 98 | ``` 99 | ALTER TABLE students 100 | DROP COLUMN remark; 101 | ``` 102 | 103 | `DESCRIBE` keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။ 104 | 105 | ![alter_drop_col](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ddl/ddl5.png) 106 | 107 | ## DROP TABLE: Removing a Table (Table ဖျက်ခြင်း) 108 | 109 | Table တစ်လုံးကိုဖျက်ချင်တဲ့အချိန်မှာတော့ DROP TABLE command ကိုအသုံးပြုနိုင်ပါတယ်။ table ထဲမှာသိမ်းဆည်းထားတဲ့ data တွေပါဖျက်တာဖြစ်တဲ့အတွက် ဂရုပြုဖို့လိုအပ်ပါတယ်။ 110 | 111 | #### Schema 112 | ``` 113 | DROP TABLE table_name; 114 | ``` 115 | 116 | #### Query 117 | ``` 118 | DROP TABLE students; 119 | ``` 120 | 121 | ![remove table](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ddl/ddl6.png) 122 | 123 | ## Constraints: Ensuring Data Integrity 124 | 125 | Table column တွေသတ်မှတ်တဲ့အချိန် data integrity ရှိဖို့အတွက်အပြင် business logic အရ constraints ဆိုတာမျိုးတွေထည့်ပေးဖို့လိုအပ်တဲ့အချိန်တွေရှိပါတယ်။ 126 | constraints အကြောင်းကိုအောက်က query တွေကြည့်ပြီးဆက်လေ့လာသွားကြပါမယ်။ 127 | 128 | ### PRIMARY KEY Constraint: 129 | 130 | `PRIMARY KEY` ဆိုတဲ့ constraint ပေးလိုက်တဲ့ column ဟာ record တိုင်းမှာ unique (မထပ်စေရ) ဖြစ်ပြီးတော့ NULL မဖြစ်ရဘူးဆိုပြီး define လုပ်ခြင်းခံလိုက်ရပါတယ်။ 131 | 132 | Table ထဲမှာရှိတဲ့ column တစ်ခုကို primary key အဖြစ်သတ်မှတ်လိုက်မယ်ဆို အဲ့ဒီ column ဟာ record တိုင်းမှာ unique ဖြစ်သွားမယ် (duplicate value မရှိတော့ဘူးလို့ဆိုလိုခြင်း)၊ column value ကို null value အလွတ်ထည့်ပေးလို့မရတော့ပါဘူး။ 133 | 134 | #### Schema 135 | ``` 136 | CREATE TABLE table_name ( 137 | column_name data_type PRIMARY KEY, 138 | ..., 139 | constraint_definition 140 | ); 141 | ``` 142 | 143 | `students` table ကိုအရင်ဖျက်ပါမယ်။ 144 | `students` table မှာ student_id ကို Primary key constraint ထည့်ပြီးတော့ဆောက်ကြည့်ပါမယ်။ 145 | 146 | #### Query 147 | ``` 148 | CREATE TABLE students ( 149 | student_id INT PRIMARY KEY, 150 | name VARCHAR(50), 151 | age INT 152 | ); 153 | ``` 154 | `DESCRIBE` keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။ 155 | 156 | ![const_primary](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ddl/ddl7.png) 157 | 158 | ### FOREIGN KEY Constraint: 159 | 160 | DDL အကြောင်းရေးရင်းနဲ့မို့ တစ်လက်စတည်း `FOREIGN KEY` အကြောင်းပါထည့်ရေးလိုက်တာပါ။ အခုဖတ်တဲ့အချိန်နားလည်ရခက်နိုင်ပေမယ့် relationships လုပ်ရတဲ့ query တွေလေ့လာတဲ့အချိန်မှာပိုနားလည်လာပါလိမ့်မယ်။ 161 | FK ဆိုတာကတော့ column တစ်ခုရဲ့ value ကိုသုံးပြီးတော့ table တစ်လုံးနဲ့တစ်လုံးချိတ်ဆက်တဲ့နေရာမှာအသုံးပြုပါတယ်။ 162 | 163 | `students` table အပြင် `clubs` ဆိုတဲ့နော် table တစ်ခု create လုပ်ရအောင်။ ကျောင်းသားတစ်ယောက်က book club, chess club စသည်ဖြင့် club တစ်ခုခုနဲ့ချိတ်ဆက်နိုင်တဲ့ဆိုတဲ့သဘောပေါ့ဗျာ။ 164 | 165 | ``` 166 | CREATE TABLE clubs( 167 | club_id INT PRIMARY KEY, 168 | club_name VARCHAR(50) 169 | ); 170 | ``` 171 | 172 | `DROP TABLE students;` 173 | ပြီးရင်လက်ရှိ club_id ဆိုတဲ့ column ထပ်ဖြည့်ပြီး students ပြန် create လုပ်ပါမယ်။ 174 | students table ထဲက club_id ကို FK အဖြစ်သတ်မှတ်ပြီး clubs ဆိုတဲ့ table ရဲ့ primary key `club_id` ကိုလှမ်း reference လုပ်လိုက်ပါမယ်။ 175 | 176 | #### Schema 177 | ``` 178 | CREATE TABLE table_name ( 179 | column_name data_type, 180 | ..., 181 | CONSTRAINT constraint_name FOREIGN KEY (column_name) REFERENCES referenced_table(referenced_column) 182 | ); 183 | ``` 184 | 185 | #### Query 186 | ``` 187 | CREATE TABLE students( 188 | student_id INT PRIMARY KEY, 189 | name VARCHAR(50), 190 | age INT, 191 | club_id INT, 192 | CONSTRAINT fk_club FOREIGN KEY (club_id) REFERENCES clubs(club_id) 193 | ); 194 | ``` 195 | 196 | `DESCRIBE` keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။ 197 | 198 | ![const_fk_des](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ddl/ddl8.png) 199 | 200 | ကိုယ်ဆောက်ခဲ့တဲ့ reference key ဝင်မဝင်ဆိုတာကို `SHOW CREATE TABLE` သုံးပြီးကြည့်ရင်ပိုမြင်နိုင်ပါတယ်။ 201 | 202 | ![const_fk_ref](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ddl/ddl9.png) 203 | 204 | ### NOT NULL Constraint: 205 | 206 | Column value ကို NULL အထည့်မခံစေချင်တဲ့အချိန်မှာတော့ NOT NULL constraint ကိုအသုံးပြုပါတယ်။ 207 | 208 | #### Schema 209 | ``` 210 | CREATE TABLE table_name ( 211 | column_name data_type NOT NULL, 212 | ..., 213 | constraint_definition 214 | ); 215 | ``` 216 | 217 | `students` table ကိုပြန်ဖျက်ပြီး `name` column ကို `NOT NULL` သုံးပြီးပြန်တည်ဆောက်ကြည့်ရအောင်။ 218 | ကျနော် `students` table ကိုပြန်ဖျက်ပြီးသုံးနေရတာက လောလောဆယ်မှာ table, column နာမည်တွေနဲ့မရှုပ်သွားစေချင်တာရယ်၊ `ALTER` command သုံးပြီးလုပ်လို့ရပေမယ့်လိုက်လုပ်ရတာခက်သွားမှာစိုးရိမ်မိလို့ပါ။ 219 | 220 | #### Query 221 | ``` 222 | CREATE TABLE students( 223 | student_id INT PRIMARY KEY, 224 | name VARCHAR(50) NOT NULL, 225 | age INT NOT NULL 226 | ); 227 | ``` 228 | 229 | `DESCRIBE` keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။ 230 | 231 | ![const_notnull](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ddl/ddl10.png) 232 | 233 | ### DEFAULT Constraint: 234 | 235 | Data insert လုပ်တဲ့အချိန်မှာ NULL value ပါလာတဲ့အခါအစားထိုးအနေနဲ့သွင်းဖို့ default value တစ်ခုခု define လုပ်တဲ့နေရာမှာအသုံးပြုပါတယ်။ 236 | 237 | #### Schema 238 | ``` 239 | CREATE TABLE table_name ( 240 | column_name data_type DEFAULT default_value, 241 | ..., 242 | constraint_definition 243 | ); 244 | ``` 245 | 246 | Students table ကိုပြန်ဖျက်ပြီး age column ကို DEFAULT သုံးပြီးပြန်တည်ဆောက်ကြည့်ရအောင်။ 247 | age value က null ဖြစ်ပြီဆို 14 ကို default အနေနဲ့ထည့်ပေးမယ်ဆိုတဲ့သဘောပါ။ 248 | 249 | #### Query 250 | ``` 251 | CREATE TABLE students ( 252 | student_id INT PRIMARY KEY, 253 | name VARCHAR(50), 254 | age INT DEFAULT 14 255 | ); 256 | ``` 257 | 258 | `DESCRIBE` keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။ 259 | 260 | ![const_default](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ddl/ddl11.png) 261 | 262 | ### UNIQUE Constraint: 263 | 264 | Table ထဲမှာပါတဲ့ columns တွေထဲမှာမှ unique ဖြစ်စေချင်တဲ့ column ရှိတဲ့အခါမှာအသုံးပြုပါတယ်။ 265 | 266 | #### Schema 267 | ``` 268 | CREATE TABLE table_name ( 269 | column_name data_type UNIQUE, 270 | ..., 271 | constraint_definition 272 | ); 273 | ``` 274 | 275 | Students table ကိုဖျက်ပြီးတော့ name column ကို unique constraint ပေးပြီးပြန် create လုပ်ကြည့်ပါမယ်။ 276 | 277 | #### Query 278 | ``` 279 | CREATE TABLE students( 280 | student_id INT PRIMARY KEY, 281 | name VARCHAR(50) UNIQUE, 282 | age INT 283 | ); 284 | ``` 285 | `DESCRIBE` keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။ 286 | 287 | ![const_unique](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ddl/ddl12.png) 288 | 289 | အသုံးများတဲ့ DDL queries တွေဖော်ပြပေးခဲ့တာဖြစ်ပါတယ်။ တိကျသေချာတဲ့ database schema တစ်ခုထွက်လာအောင်တည်ဆောက်တဲ့နေရာမှာ DDL ကိုကျွမ်းကျင်ဖို့က အလွန်အရေးပါပါတယ်။ 290 | နောက်အပိုင်းမှာ DQL အကြောင်းကိုဆက်လေ့လာသွားကြပါမယ်။ 291 | -------------------------------------------------------------------------------- /diving_queries.md: -------------------------------------------------------------------------------- 1 | # Diving Into SQL Queries 2 | 3 | Diving လုပ်တယ်လို့ဆိုထားပေမယ့် ဒီအပိုင်းမှာတော့ Query ဆိုတာဘယ်လိုသဘောရှိလဲဆိုတာကို သဘောပေါက်ရုံလောက်ပဲ intro အရင်ဝင်ပြီးတော့ဖြည်းဖြည်းခြင်း step up လုပ်ပြီးလေ့လာသွားကြပါမယ်။ 4 | 5 | Query တွေရေးတဲ့အချိန်မှာ CLI (command line interface) ကိုအသုံးပြုသွားပါမယ်။ CLI နဲ့ရင်းနှီးစေချင်တာကတစ်ကြောင်း၊ CLI မကျွမ်းကျင်သေးဘဲနဲ့ GUI (graphical user interface) ကိုတန်းမသုံးစေချင်တာကြောင့်လည်းပါပါတယ်။ 6 | 7 | စလိုက်ကြရအောင်၊ ကျနော်ကတော့ window OS ကိုအသုံးပြုနေပါတယ်။ တစ်ခြား OS အသုံးပြုနေတဲ့သူတွေကလည်းသက်ဆိုင်ရာ application ကိုဖွင့်ပြီးလိုက်လုပ်ကြည့်နိုင်ပါတယ်။ နားမလည်ရင် environment setup အပိုင်းကိုပြန်ဖတ်ကြည့်ပေးပါခင်ဗျ။ 8 | 9 | MySQL 8.0 command line client ကို window start menu ကနေတစ်ဆင့်ဖွင့်လိုက်ပါမယ်။ password ရိုက်ထည့်ပြီးရင်အသုံးပြုနိုင်ပါပြီ။ 10 | 11 | ![Opening CLI](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ds1.png) 12 | 13 | Query တွေစမ်းရေးကြည့်နိုင်ဖို့အတွက် Database တစ်လုံးအရင်ဆောက်ကြည့်ရအောင်။ 14 | Database ဆောက်ဖို့အတွက် schema ပါ။ 15 | #### Schema 16 | `CREATE DATABASE database_name;` 17 | 18 | `database_name` မှာကျနော်တို့ဆောက်မည့် နာမည်ကိုအစားထိုးလိုက်ပါမယ်။ 19 | ဒီတစ်ခေါက်စားသောက်ဆိုင်ဆိုတဲ့ restaurant db ကိုဆောက်ပါမယ်။ 20 | #### Query 21 | `CREATE DATABASE restaurant;` 22 | 23 | `show databases` ကိုသုံးပြီးပြန်စစ်ကြည့်မယ်ဆို restaurant db ကိုတွေ့ရပါမယ်။ 24 | 25 | ![Creating database](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ds2.png) 26 | 27 | ဆောက်ထားတဲ့ restaurant db ကိုအသုံးပြုရန် 28 | `use restaurant` ဆိုပြီးရိုက်လိုက်ပါမယ်။ 29 | 30 | ![Using database](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ds3.png) 31 | 32 | ဆိုင်မှာရနိုင်တဲ့ဟင်းပွဲတွေကိုသိမ်းဖို့အတွက် menu ဆိုတဲ့ table ဆောက်ပါမယ်။ 33 | 34 | #### Schema 35 | 36 | ``` 37 | CREATE TABLE table_name ( 38 | column_name1 data_type1 constraints, 39 | column_name2 data_type2 constraints, 40 | ... 41 | ); 42 | ``` 43 | table_name နေရာမှာ table နာမည် 44 | column_name နေရာမှာထည့်ချင်တဲ့ column နာမည် 45 | data_type နေရာမှာသိမ်းဆည်းချင်တဲ့ပုံစံ 46 | constraints မှာလိုတဲ့ပမာဏကိုထည့်ပြီး table ဆောက်ပါမယ်။ 47 | 48 | #### Query 49 | ``` 50 | CREATE TABLE menu (name VARCHAR(100), price INTEGER(10), category VARCHAR(50), created_date DATE, updated_date DATE ); 51 | ``` 52 | `show tables` နဲ့ပြန်စစ်ကြည့်မယ်ဆို ဒီလိုမြင်ရပါလိမ့်မယ်။ 53 | 54 | ![Creating table](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ds4.png) 55 | 56 | Table structure ကိုပါကြည့်ချင်တယ်ဆို 57 | `DESCRIBE` ဆိုတဲ့ keyword ကိုအသုံးပြုနိုင်ပါတယ်။ 58 | 59 | ![Checking table structure](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ds5.png) 60 | 61 | Table ဆောက်ပြီးပြီဆိုတော့ data နည်းနည်းထည့်ကြည့်ရအောင်။ 62 | #### Schema 63 | ``` 64 | INSERT INTO table_name (column1, column2, ...) 65 | VALUES (value1, value2, ...), 66 | (value1, value2, ...), 67 | ...; 68 | ``` 69 | column နေရာမှာ column name တွေအစားထိုးပြီး value နေရာမှာထည့်ချင်တဲ့တန်ဖိုးတွေကိုအစားထိုးလိုက်ပါမယ်။ 70 | #### Query 71 | ``` 72 | INSERT INTO menu (name, price, category, created_date, updated_date) VALUES ('Dish A', 10000, 'Main Course', '2023-07-28', '2023-07-28'), ('Dish B', 6000, 'Appetizer', '2023-07-28', '2023-07-28'), ('Dish C', 5000, 'Dessert', '2023-07-28', '2023-07-28'); 73 | ``` 74 | ![Inserting data](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ds6.png) 75 | 76 | Data တွေကိုပြန်စစ်ကြည့်ရအောင်။ 77 | 78 | `select * from menu` 79 | 80 | ![Selecting data](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ds7.png) 81 | 82 | menu table ထဲမှာရှိတဲ့ data အားလုံးကိုပြပါလို့ဆိုလိုတာဖြစ်ပါတယ်။ SELECT နဲ့ FROM keyword ကိုအသုံးပြုပါတယ်။ 83 | `*` ကတော့အားလုံးကိုဆိုလိုခြင်းဖြစ်ပါတယ်။ 84 | 85 | အားလုံးကိုမဆွဲထုတ်ချင်ဘူး၊ column တစ်ခုတည်းဆွဲချင်တယ်ဆိုလည်းရပါတယ်။ 86 | `*` နေရာမှာ column name ကိုအစားထိုးလိုက်ရုံပါပဲ။ 87 | 88 | #### Query 89 | `select name from menu;` 90 | 91 | ![Selecting a column](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ds8.png) 92 | 93 | တစ်ခုထက်ပိုတဲ့ column ကိုဆွဲချင်တယ်ဆိုရင်လည်း comma ခံပြီးဆွဲထုတ်လို့ရပါတယ်။ 94 | #### Query 95 | `select name,price from menu;` 96 | 97 | ![Selecting multiple columns](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ds9.png) 98 | 99 | ရိုးရိုး SELECT ကိုသုံးပြီး data ထုတ်ရာကနေ condition လေးတွေခံပြီးထုတ်ကြည့်ရအောင်။ `menu` table ထဲကမှ `category` က `Main Course` ဖြစ်တဲ့ item ကိုပဲလိုချင်တယ်ဆိုပါစို့။ 100 | `WHERE` ဆိုတဲ့ keyword ကိုသုံးပြီးဒီလိုဆွဲထုတ်လို့ရပါတယ်။ 101 | #### Schema 102 | ``` 103 | SELECT column1, column2, ... 104 | FROM table_name 105 | WHERE condition; 106 | ``` 107 | 108 | condition နေရာမှာ category က Main Course ပါဆိုတဲ့ category = 'Main Course' ကကိုအစားထိုးပေးလိုက်ပါမယ်ဆို Main Course 109 | ဖြစ်တဲ့ record တစ်ကြောင်းပဲထွက်လာတာကိုမြင်ရပါမယ်။ 110 | #### Query 111 | ``` 112 | SELECT * FROM menu WHERE category = 'Main Course'; 113 | ``` 114 | ![Select where](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ds10.png) 115 | 116 | သတိထားမိလားမသိဘူး၊ ကျနော် sql keywords တွေကို စာလုံးအသေးနဲ့ရောအကြီးနဲ့ရောသုံးသွားတယ်၊ နှစ်ခုလုံးအလုပ်လုပ်ပါတယ်။ 117 | သို့သော်ဖတ်ရလွယ်ကူရန်နဲ့ sql keywords တွေမှန်းသိသာအောင် capital letter ကိုသုံးတာကပိုပြီးသင့်တော်စေပါတယ်။ 118 | 119 | `menu` table ထဲကဈေး 10000 ထက်နည်းတဲ့ items တွေကိုဆွဲထုတ်ကြည့်ရအောင်။ `<` less than character ကိုအသုံးပြုပါမယ်။ 120 | #### Query 121 | ``` 122 | SELECT * FROM menu WHERE price < 10000; 123 | ``` 124 | 10000 ထက်နည်းတဲ့ items နှစ်ခုကိုတွေ့ရပါမယ်။ 125 | 126 | ![Select where](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ds11.png) 127 | 128 | လောလောဆယ်တော့ဒီလောက်ထိပဲသွားထားပါမယ်။ နောက်ပိုင်း queries တွေဆက်ရေးကြပါဦးမယ်။ 129 | table ကို delete ပြန်ချကြည့်ရအောင်။ 130 | #### Schema 131 | ``` 132 | DROP TABLE table_name; 133 | ``` 134 | #### Query 135 | table_name မှာ `menu` ကိုအစားထိုးလိုက်ပါမယ်။ 136 | ``` 137 | DROP TABLE menu; 138 | ``` 139 | ![Deleting table](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/ds12.png) 140 | 141 | 142 | Queries အကြောင်းနည်းနည်းတီးမိခေါက်မိရှိသွားပြီဆိုတော့ DDL, DQL, DML ဒီသုံးခုအကြောင်းကိုဆက်ရှင်းပေးသွားပါမယ်။ 143 | SQL queries ကိုအဓိကအားဖြင့်သုံးမျိုးခွဲခြားနိုင်ပါတယ်။ 144 | 145 | ### Data Definition Language (DDL): 146 | DDL ကတော့ database structure တွေကိုစီမံဖို့အတွက်အသုံးပြုတဲ့ query တွေကိုဆိုလိုခြင်းဖြစ်ပါတယ်။ 147 | data တွေကိုစီမံတာမဟုတ်ဘဲ database objects တွေကိုကိုင်တွယ်နိုင်ဖို့အတွက်အသုံးပြုတာဖြစ်ပါတယ်။ 148 | 149 | ### Data Query Language (DQL): 150 | DQL ကတော့ database ထဲက data တွေကိုဆွဲထုတ်ဖို့အတွက်အသုံးပြုတဲ့ query တွေကိုဆိုလိုခြင်းဖြစ်ပါတယ်။ 151 | များသောအားဖြင့် SELECT statements တွေဖြစ်ပါတယ်။ 152 | 153 | ### Data Manipulation Language (DML): 154 | DML ကတော့ database ထဲက data တွေကိုသိမ်းဆည်း၊ပြုပြင်၊ဖျက်ဆည်းခြင်း INSERT, UPDATE, DELETE လုပ်ဖို့အတွက်အသုံးပြုတဲ့ query တွေကိုဆိုလိုခြင်းဖြစ်ပါတယ်။ 155 | 156 | နောက်အပိုင်းတွေကစပြီး ဒီ categories သုံးခုကိုကျောရိုးထားပြီးတော့ query တွေလက်တွေ့ရေးသားပြီးလေ့လာသွားကြပါမယ်။ 157 | -------------------------------------------------------------------------------- /dml.md: -------------------------------------------------------------------------------- 1 | ## DML (Data Manipulation Language) 2 | 3 | Database ထဲမှာရှိတဲ့ data တွေကိုလိုသလိုပြင်ဆင်ဖို့အတွက်(Manipulationလုပ်ဖို့အတွက်)အသုံးပြုပါတယ်။ DML queries တွေမှာ အဓိကအားဖြင့် SELECT, INSERT, UPDATE, DELETE keyword တွေကိုတွေ့ရမှာဖြစ်ပါတယ်။ 4 | 5 | SELECT နဲ့ INSERT query ကိုတော့ရှေ့အပိုင်းတွေမှာလည်းတွေ့ပြီးသားဖြစ်တဲ့အတွက် ဒီအပိုင်းမှာတော့ UPDATE, DELETE queries တွေကိုအာရုံစိုက်ပြီးကြည့်သွားကြပါမယ်။ 6 | 7 | ### INSERT 8 | အရှေ့အပိုင်းမှာသုံးခဲ့တဲ့ `products` table ကိုဆက်သုံးကြရအောင်။
9 | `select` အရင်ဆွဲကြည့်မယ်၊ records 8ကြောင်းရှိတာကိုတွေ့ပါမယ်၊ INSERT query ပြန်နွေးတဲ့အနေနဲ့ တစ်ကြောင်းထပ်ထည့်ကြည့်ပါမယ်။ 10 | 11 | `INSERT INTO products VALUES(9, 'Tablet', 'Electronics', 500, 50, 'SupplierA');` 12 | 13 | ![DML1](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dml/dml1.png) 14 | 15 | --- 16 | ### UPDATE 17 | Table ထဲမှာရှိတဲ့ data တွေကို update လုပ်ကြပါမယ်။ 18 | `UPDATE` ဆိုတဲ့ command ကိုသုံးပါတယ်။ 19 | 20 | #### Schema 21 | ``` 22 | UPDATE table_name 23 | SET column_name = value 24 | WHERE column_name = value; 25 | ``` 26 | 27 | Products table ထဲမှာရှိတဲ့ `product_name` က `Smartphone` ဖြစ်တဲ့ records တွေရဲ့ price တန်ဖိုးကိုပြင်ကြည့်ပါမယ်။ ဒါဆို query ကဒီလိုဖြစ်ပါမယ်။ 28 | 29 | ``` 30 | UPDATE products 31 | SET price = 649.99 32 | WHERE product_name = 'Smartphone'; 33 | ``` 34 | 35 | `select` နဲ့ပြန်ခေါ်ကြည့်မယ်ဆို `product_name` က `Smartphone` ဖြစ်တဲ့ record ရဲ့ `price` တန်ဖိုးပြောင်းသွားတာကိုမြင်နိုင်မှာဖြစ်ပါတယ်။
36 | `select` ဆွဲတဲ့နေရာမှာလေ့ကျင့်တဲ့အနေနဲ့ အောက်က screenshot ကိုမကြည့်သေးဘဲမိမိဘာသာစမ်းပြီးရေးကြည့်ဖို့တိုက်တွန်းချင်ပါတယ်။ 37 | 38 | Schema 39 | `select * from table_name where condition` 40 | ![DML2](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dml/dml2.png) 41 | --- 42 | `product_name` က `Desk` ဖြစ်တဲ့ records တွေရဲ့ `stock_quantity` တန်ဖိုးကိုထပ်ပြီးပြင်ဆင်ကြည့်ပါမယ်။ 43 | 44 | ``` 45 | UPDATE products 46 | SET stock_quantity = 20 47 | WHERE product_name = 'Desk'; 48 | ``` 49 | ထုံးစံအတိုင်း update query ရဲ့ result ကို select query ပြန်ရေးပြီးကြည့်နိုင်ပါတယ်။ 50 | 51 | ![DML3](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dml/dml3.png) 52 | 53 | --- 54 | 55 | ဒီတစ်ခါတော့ value set လုပ်တဲ့နေရာမှာ calculation လုပ်ပြီးပြင်ဆင်ကြည့်ရအောင်။
56 | 57 | `category` က `Electronics` ဖြစ်တဲ့ records တွေရဲ့ `stock_quantity` တန်ဖိုးကို မူလရှိရင်းစွဲတန်ဖိုးထက် ၁၀ခုပေါင်းထည့်ချင်တယ်ဆိုပါစို့၊ ဒီလိုမျိုးရေးနိုင်ပါတယ်။ 58 | 59 | ``` 60 | UPDATE products 61 | SET stock_quantity = stock_quantity + 10 62 | WHERE category = 'Electronics'; 63 | ``` 64 | အလားတူအခြားသော ပေါင်း၊နုတ်၊မြောက်၊စား signs တွေလည်းသုံးနိုင်ပါတယ်။ 65 | 66 | ![DML4](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dml/dml4.png) 67 | 68 | --- 69 | 70 | အောက်က example မှာတော့ multiplication sign ကိုသုံးပြထားပါတယ်။
71 | `category` က `Clothing` ဖြစ်တဲ့ records တွေရဲ့ `price` ကိုနှစ်ဆတင်ပြထားပါတယ်။ 72 | 73 | ``` 74 | UPDATE products 75 | SET price = price * 2 76 | WHERE category = 'Clothing'; 77 | ``` 78 | 79 | ![DML5](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dml/dml5.png) 80 | 81 | --- 82 | 83 | ### DELETE 84 | 85 | #### Schema 86 | ``` 87 | DELETE FROM table_name WHERE condition; 88 | ``` 89 | 90 | `product_name` က `Shoes` ဖြစ်တဲ့ records တွေကိုဖျက်ချပါမယ်။
91 | ဒါဆို query ကဒီလိုဖြစ်ပါမယ်။ 92 | 93 | ``` 94 | DELETE FROM products 95 | WHERE product_name = 'Shoes'; 96 | ``` 97 | 98 | ပျက်သွားလားဆိုတာကို select ပြန်ဆွဲပြီးကြည့်နိုင်ပါတယ်။ Delete ချတဲ့နေရာမှာ WHERE condition မလိုက်လို့လည်းရပါတယ်။
99 | မလိုက်ဘူးဆိုရင်တော့ table ထဲမှာရှိတဲ့ data တွေအကုန်ပျက်သွားမှာဖြစ်ပါတယ်။ 100 | 101 | ![DML6](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dml/dml6.png) 102 | 103 | --- 104 | အရှေ့မှာ example တွေပြခဲ့တဲ့အတိုင်း WHERE condition တွေနောက်မှာ filter လုပ်တဲ့ signs တွေလိုက်နိုင်ပါတယ်(=, <, > etc.)။
105 | DELETE query တွေမှာလည်းဒီလို filter တွေလုပ်ပြီးသုံးနိုင်ပါတယ်။ 106 | 107 | `stock_quantity` 30 အောက်ရောက်နေတဲ့ records တွေဖျက်ချင်တယ်ဆိုပါစို့။ 108 | 109 | ``` 110 | DELETE FROM products 111 | WHERE stock_quantity < 10; 112 | ``` 113 | 114 | ![DML7](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dml/dml7.png) 115 | 116 | 117 | အရှေ့က DQL မှာရေးခဲ့တဲ့ `NULL`, `NOT NULL` ဒီလို filter တွေခံပြီးတော့လည်းသုံးနိုင်ပါတယ်။ 118 | ဥပမာ `supplier` တန်ဖိုးက `NULL` ဖြစ်နေတဲ့ records တွေကိုဖျက်ချင်တယ်ဆို 119 | 120 | ``` 121 | DELETE FROM products 122 | WHERE supplier IS NULL; 123 | ``` 124 | 125 | DML ရဲ့ကြောရိုးက ဒီ command ၄ခုပဲဖြစ်ပါတယ်။ သဘောတရားကိုအရင်နားလည်စေချင်တဲ့အတွက်ရိုးရှင်းတဲ့ example queries တွေနဲ့ပဲရေးပြပေးထားပါတယ်။ 126 | 127 | 128 | DDL, DQL, DML ရဲ့သဘောတရားကိုနားလည်သွားပြီဆိုနောက်အပိုင်းတွေမှာပိုပြီး advanced ဖြစ်တဲ့ queries ကိုလေ့လာသွားကြပါမယ်။ 129 | 130 | advanced ဖြစ်တဲ့ queries လို့ဆိုပေမယ့်လည်းလေ့လာခဲ့တဲ့ DDL, DQL, DML ဆိုတဲ့ category သုံးခုပေါ်မှာပဲ based လုပ်သွားမှာဖြစ်တဲ့အတွက်လေ့လာရလွယ်ကူမှာဖြစ်ပါတယ်။ 131 | -------------------------------------------------------------------------------- /dnt.md: -------------------------------------------------------------------------------- 1 | # Date and Time 2 | 3 | ဒီအပိုင်းမှာတော့ date, time ရဲ့ data type အကြောင်းနဲ့အသုံးပြုပုံ functions တွေအကြောင်းကိုရေးသွားမှာဖြစ်ပါတယ်။ 4 | 5 | `DATE, TIME` data type အသစ်တွေကိုစမ်းမှာဖြစ်တဲ့အတွက်လက်ရှိရှိပြီးသား `students` table ကိုဖြုတ်ချပြီး table အသစ်ဆောက်လိုက်ပါမယ်။ 6 | 7 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt1.png) 8 | 9 | column အသစ်သုံးခုထည့်ပါမယ်။ 10 | `birth_date` ကို `Date` 11 | `class_time` အတန်းထဲရှိတဲ့အချိန်ကို `TIME` 12 | `last_updated` လက်ရှိ record/row ကိုနောက်ဆုံးပြင်ဆင်ထားချိန်ကို `DATETIME` 13 | အဖြစ်သတ်မှတ်ပေးထားလိုက်ပါတယ်။ သုံးမျိုးလုံးကိုစမ်းပြပေးချင်လို့ပါ။ 14 | 15 | အောက်က `CREATE` query နဲ့ data ထည့်မယ့် `INSERT` query ကိုအသုံးပြုနိုင်ပါတယ်။ 16 | 17 | ``` 18 | CREATE TABLE students ( 19 | student_id INT PRIMARY KEY, 20 | name VARCHAR(50), 21 | nick_name VARCHAR(50), 22 | age INT, 23 | major VARCHAR(50), 24 | birth_date DATE, 25 | class_time TIME, 26 | last_updated DATETIME 27 | ); 28 | ``` 29 | 30 | ``` 31 | INSERT INTO students (student_id, name, nick_name, age, major, birth_date, class_time, last_updated) 32 | VALUES 33 | (1, 'John Doe', 'JD', 20, 'Computer Science', '2000-05-15', '14:30:00', '2022-10-18 08:45:00'), 34 | (2, 'Jane Smith', 'JS', 22, 'Mathematics', '1999-09-10', '10:45:00', '2021-08-25 15:20:00'), 35 | (3, 'Alice Johnson', 'AJ', 21, 'History', '2002-03-01', '18:15:00', '2023-01-12 12:30:00'), 36 | (4, 'Bob Williams', 'BW', 20, 'Chemistry', '2001-08-12', '08:00:00', '2022-05-07 20:10:00'), 37 | (5, 'Eva Brown', 'EB', 22, 'Biology', '1999-12-05', '21:20:00', '2021-11-30 11:55:00'), 38 | (6, 'Charlie Davis', 'CD', 21, 'Physics', '2000-06-20', '12:10:00', '2022-03-17 17:40:00'), 39 | (7, 'John Doe', 'JD', 20, 'Computer Science', '2000-05-15', '14:30:00', '2022-10-18 08:45:00'), -- Duplicate name data 40 | (8, 'Alice Johnson', 'AJ', 21, 'History', '2002-03-01', '18:15:00', '2023-01-12 12:30:00'); -- Duplicate name data 41 | ``` 42 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt2.png) 43 | 44 | --- 45 | 46 | 47 | များသောအားဖြင့်ကျနော်တို့မြင်တွေ့ရမယ့် type ပုံစံတွေက 48 | DATE (နေ့စွဲ) 49 | TIME (အချိန်) 50 | DATETIME (နေ့စွဲ+အချိန်) 51 | 52 | Format ကတော့ 53 | DATE ဆို (YYYY-MM-DD) 54 | TIME ဆို (HH:MI:SS) 55 | DATETIME ဆို (YYYY-MM-DD HH:MI:SS) ဆိုပြီးရှိပါတယ်။ 56 | ဒီ format အထားအသိုကိုလည်းလိုသလိုပြောင်းနိုင်ပါတယ်။ 57 | ``` 58 | YYYY - year 59 | MM - month 60 | DD - date 61 | HH - hour 62 | MI - minute 63 | SS- second 64 | ``` 65 | 66 | Keyword တွေကအသုံးပြုတဲ့ DBMS ပေါ်လိုက်ပြီးတော့ပြောင်းနိုင်တာကိုလည်းသတိချပ်ထားရပါတယ်။ အခုကျနော်တို့က MySQL ကိုသုံးနေတာဖြစ်ပါတယ်။ 67 | 68 | ## NOW, CURRENT_DATE, CURRENT_TIMESTAMP 69 | 70 | လက်ရှိအချိန်၊နေ့ရက်တွေကိုရချင်တယ်ဆို ဒီ function တွေကိုအောက်ကလိုအသုံးပြုနိုင်ပါတယ်။ 71 | 72 | ``` 73 | SELECT NOW() AS CurrentDateAndTime; 74 | ``` 75 | 76 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt3.png) 77 | 78 | --- 79 | ``` 80 | SELECT CURRENT_DATE AS CurrentDate; 81 | ``` 82 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt4.png) 83 | 84 | ``` 85 | SELECT CURRENT_TIMESTAMP AS CurrentTimestamp; 86 | ``` 87 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt5.png) 88 | 89 | --- 90 | 91 | ## TIMESTAMPDIFF 92 | 93 | အချိန်ကွာခြားချက်ကိုသိနိုင်ဖို့အတွက် `TIMESTAMPDIFF` ကိုအသုံးပြုနိုင်ပါတယ်။ 94 | 95 | 96 | ကျောင်းသားတွေရဲ့အသက်ကိုတွက်ကြည့်ရအောင်။ 97 | တွက်ဖို့ဆိုလက်ရှိအချိန်နဲ့ `birth_date` column ကိုတန်ဖိုးကွာခြားချက်ကို `YEAR` ဆိုတဲ့ filter နဲ့ချလိုက်မယ်ဆိုကျောင်းသားတွေရဲ့ လက်ရှိအသက်ရလာနိုင်ပါတယ်။ အောက်ကရေးပုံကိုကြည့်နိုင်ပါတယ်။ 98 | 99 | ``` 100 | SELECT name, TIMESTAMPDIFF(YEAR, birth_date, CURDATE()) AS AgeInYears 101 | FROM students; 102 | ``` 103 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt6.png) 104 | 105 | --- 106 | 107 | ဒီတစ်ခါအသက်တွေကို YEAR နဲ့မဟုတ်ဘဲ MONTH နဲ့ကြည့်ရအောင်။ `YEAR` keyword အစား `MONTH` ဆိုတဲ့ keyword ကိုအစားထိုးအသုံးပြုနိုင်ပါတယ်။ 108 | 109 | ``` 110 | SELECT name, TIMESTAMPDIFF(MONTH, birth_date, CURDATE()) AS AgeInMonths 111 | FROM students; 112 | ``` 113 | 114 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt7.png) 115 | 116 | --- 117 | 118 | ## DATE_ADD, DATE_SUB 119 | 120 | နေ့ရက်အချိန်တွေကိုပေါင်းခြင်း၊ နုတ်ခြင်းတို့လည်းလုပ်ဆောင်နိုင်ပါတယ်။ 121 | ပေါင်းတာနုတ်တာမြင်သာအောင် query မ run ခင်အရင် select * နဲ့ အချိန်၊နေ့စွဲတွေကိုကြည့်ထားနိုင်ပါတယ်။ 122 | 123 | `last_updated` ဆိုတဲ့ column ရဲ့တန်ဖိုးကို အချိန် ၂ နှစ်ထည့်ပေါင်းကြည့်ရအောင်။ 124 | 125 | ``` 126 | SELECT name, DATE_ADD(last_updated, INTERVAL 2 YEAR) AS NewLastUpdated 127 | FROM students; 128 | ``` 129 | 130 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt8.png) 131 | 132 | --- 133 | 134 | `class_time` column ရဲ့အချိန်တန်ဖိုးထဲကမိနစ်သုံးဆယ်နုတ်ကြည့်ရအောင်။ 135 | 136 | ``` 137 | SELECT name, DATE_SUB(class_time, INTERVAL 30 MINUTE) AS NewClassTime 138 | FROM students; 139 | ``` 140 | 141 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt9.png) 142 | 143 | --- 144 | 145 | ## EXTRACT 146 | 147 | column ထဲက date time တန်ဖိုးထဲကမှကိုယ်လိုချင်တဲ့အပိုင်းကိုပဲထုတ်ယူလို့လည်းရပါတယ်။ 148 | ဥပမာ `YYYY-MM-HH` ထဲ က `YYYY` ကိုလည်းလိုချင်တယ်၊ `MM` ပဲလိုချင်တယ်ဆိုတဲ့အခြေအနေမျိုးတွေမှာ `EXTRACT`ကိုသုံးနိုင်ပါတယ်။ 149 | 150 | `birth_date` column ထဲကမှ `year` ကိုပဲဆွဲထုတ်ကြည့်ကြည့်ရအောင်။ 151 | ``` 152 | SELECT name, EXTRACT(YEAR FROM birth_date) AS BirthYear 153 | FROM students; 154 | ``` 155 | 156 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt10.png) 157 | 158 | --- 159 | 160 | `class_time` column ထဲက `hour` ကိုပဲဆွဲထုတ်ကြည့်ရအောင်။ 161 | ``` 162 | SELECT name, EXTRACT(HOUR FROM class_time) AS ClassHour 163 | FROM students; 164 | ``` 165 | 166 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt11.png) 167 | 168 | --- 169 | 170 | ## DATE_FORMAT 171 | 172 | အရှေ့မှာ date, time format တွေကိုလိုသလိုပြောင်းလို့ရတယ်လို့ကျနော်ပြောခဲ့ပါတယ်။ 173 | `DATE_FORMAT` ဆိုတဲ့ function ကိုသုံးပြီးတော့ပြောင်းနိုင်ပါတယ်။ 174 | 175 | `birth_date` ကို format နောက်တစ်မျိုးဖြစ်တဲ့ `Month DD, YYYY` အဖြစ်ပြောင်းကြည့်ပါမယ်။ 176 | ``` 177 | SELECT name, DATE_FORMAT(birth_date, '%M %d, %Y') AS FormattedBirthDate 178 | FROM students; 179 | ``` 180 | 181 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt12.png) 182 | 183 | --- 184 | 185 | `last_updated` ကိုလည်း `YYYY-MM-DD HH:MI AM/PM` အဖြစ်ပြောင်းကြည့်ပါမယ်။ 186 | 187 | ``` 188 | SELECT name, DATE_FORMAT(last_updated, '%Y-%m-%d %h:%i %p') AS FormattedLastUpdated 189 | FROM students; 190 | ``` 191 | 192 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt13.png) 193 | 194 | --- 195 | 196 | `class_time` ကိုလည်း `HH:MI AM/PM` အဖြစ်ပြောင်းကြည့်ပါမယ်။ 197 | 198 | ``` 199 | SELECT name, DATE_FORMAT(class_time, '%h:%i %p') AS FormattedClassTime 200 | FROM students; 201 | ``` 202 | 203 | ![dnt](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dnt/dnt14.png) 204 | 205 | --- 206 | 207 | တစ်ခြားသော function တွေလည်းများစွာရှိပါသေးတယ်၊ ကျနော်လိုသလောက်ပဲထုတ်နုတ်ထားလိုက်တာပါ။အခုအပိုင်းကအရင်ရေးခဲ့တဲ့ queries တွေနဲ့မတူဘဲနည်းနည်းလေးခက်ကောင်းခက်နိုင်ပါတယ်။ function တွေအသုံးပြုတာပါလာတာရယ်၊ format လေးတွေပါလာတာရယ်ကြောင့်ပါ။ သို့ပေမယ့် များများလေ့ကျင့်လိုက်ရင်တော့ကျင့်သားရလာမှာပါ။ 208 | 209 | `DATE & TIME` data တွေကမရှိမဖြစ်ပါလေ့ရှိတာကြောင့် ကိုယ်လိုသလိုဆွဲထုတ်ချင်လာတဲ့အချိန်မှာအခုပြောခဲ့တဲ့အရာလေးတွေကအသုံးဝင်လာမယ်လို့ထင်ပါတယ်။ 210 | -------------------------------------------------------------------------------- /dql.md: -------------------------------------------------------------------------------- 1 | # DQL (Data Query Language) 2 | 3 | Database ထဲက data တွေကိုဆွဲထုတ်လိုတဲ့အချိန်မှာ DQLလို့ခေါ်တဲ့ query တွေကိုအသုံးပြုပါတယ်။ 4 | `SELECT` ကိုအသုံးပြုပြီး အနောက်မှာ condition အခြေအနေအမျိုးမျိုးလိုက်ကာ data တွေကို filter လုပ်နိုင်ဖို့အတွက် `WHERE` ဆိုတဲ့ keyword ကိုသုံးပါတယ်။ 5 | ဒီအပိုင်းမှာတော့ DQL ကိုပေါ်လွင်အောင်ရိုးရှင်းတဲ့နမူနာ queries တွေနဲ့အတူလေ့လာသွားကြပါမယ်။ 6 | 7 | MySQL command line client ကိုဖွင့်ပြီးတော့ DQL queries တွေစမ်းရေးကြည့်ဖို့အတွက် database အသစ်တစ်ခုဆောက်ရအောင်။ 8 | 9 | `CREATE DATABASE dql_test;` 10 | ဆောက်ပီးရင်သုံးဖို့အတွက် ready ဖြစ်အောင် 11 | `use dql_test;` ဆိုပြီးလုပ်ပေးထားလိုက်ပါမယ်။ 12 | 13 | ![DQL1](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dql/dql1.png) 14 | - 15 | 16 | DQL queries တွေစမ်းဖို့အတွက် `products` ဆိုတဲ့ table တစ်ခုဆောက်ပါမယ်။ 17 | 18 | ``` 19 | CREATE TABLE products ( 20 | product_id INT PRIMARY KEY, 21 | product_name VARCHAR(255), 22 | category VARCHAR(50), 23 | price DECIMAL(10, 2), 24 | stock_quantity INT, 25 | supplier VARCHAR(100) 26 | ); 27 | ``` 28 | 29 | ![DQL2](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dql/dql2.png) 30 | - 31 | 32 | Table ဆောက်ပြီးပြီးဆိုတော့ dummy data တစ်ချို့ထည့်သွင်းပါမယ်။ 33 | `INSERT` statement ကိုသုံးပါမယ်။ 34 | ``` 35 | INSERT INTO products VALUES 36 | (1, 'Laptop', 'Electronics', 899.99, 25, 'TechCorp'), 37 | (2, 'Smartphone', 'Electronics', 599.99, 50, 'GadgetZone'), 38 | (3, 'T-shirt', 'Clothing', 19.99, 100, 'FashionRUs'), 39 | (4, 'Desk', 'Furniture', 149.99, 15, 'HomeFurnish'), 40 | (5, 'Headphones', 'Electronics', 89.99, 75, 'AudioTech'), 41 | (6, 'Shoes', 'Footwear', 59.99, 40, NULL), 42 | (7, 'Backpack', 'Accessories', 39.99, 30, 'GearUp'), 43 | (8, 'Watch', 'Accessories', 129.99, 10, 'TimePieces'); 44 | ``` 45 | 46 | ![DQL3](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dql/dql3.png) 47 | - 48 | 49 | DQL ဖြစ်တဲ့အတွက်ဒီအပိုင်းမှာ `SELECT` နဲ့ `WHERE` keyword ကိုအဓိကသုံးသွားမှာဖြစ်ပြီးတော့ query schema ကတော့အောက်ပါအတိုင်းဖြစ်ပါတယ်။ 50 | ``` 51 | SELECT column1, column2, ... 52 | FROM products 53 | WHERE condition; 54 | ``` 55 | Condition နေရာမှာတော့လိုအပ်သလိုပုံစံမျိုးစုံလိုက်နိုင်ပါတယ်။ အောက်ကနမူနာတွေမှာဆက်ဖော်ပြပေးထားပါတယ်။ 56 | 57 | ### Equal 58 | ပထမဦးဆုံး products table ထဲကနေ `category` column က `Electronics` ဖြစ်တဲ့ value ကိုဆွဲထုတ်ကြည့်ပါမယ်။ 59 | column value အားလုံးလိုချင်တဲ့အတွက် * ကိုသုံးပါမယ်။ 60 | 61 | ``` 62 | SELECT * 63 | FROM products 64 | WHERE category = 'Electronics'; 65 | ``` 66 | တူညီတဲ့ value ကိုလိုချင်တဲ့အတွက် `=` sign ကိုအသုံးပြုပါတယ်။ 67 | 68 | ![DQL4](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dql/dql4.png) 69 | - 70 | 71 | ### Greater than 72 | ဈေးနှုန်း price column ကို 100 ကျော်တဲ့ records တွေကိုဆွဲထုတ်ကြည့်ပါမယ်။ 73 | `*` မသုံးဘဲနဲ့လိုချင်တဲ့ column တွေကိုပဲ comma နဲ့ဖြတ်ပြီးသတ်မှတ်ပေးလိုက်ပါမယ်။ 74 | 75 | ``` 76 | SELECT product_name, price 77 | FROM products 78 | WHERE price > 100; 79 | ``` 80 | 100`ကျော်`တဲ့ records ဆိုတဲ့အတွက် `>` sign ကိုအသုံးပြုပါတယ်။ 81 | အောက်ရောက်တယ်ဆိုရင် `<` less than sign ကိုသုံးပါမယ်။
82 | အားလုံးသိပြီးထားတဲ့ sign တွေအတိုင်းပါပဲ
83 | less than and equal ဆို `≤`
84 | greater than and equal ဆို `≥` အသုံးပြုပါတယ်။ 85 | 86 | ![DQL5](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dql/dql5.png) 87 | - 88 | 89 | ### AND 90 | ဒီတစ်ခါ `AND` ဆိုတဲ့ keyword ကိုသုံးပြီး condition နှစ်ခု combine လုပ်ကြည့်ပါမယ်။ လွယ်ကူပါတယ်၊ condition နှစ်ခုကြားမှာအောက်ကလို `AND` ဆိုပြီးခံပေးလိုက်ရုံပါပဲ။
condition ကတော့ stock_quantity column ကို 50 အောက်ရောက်နေပြီးတော့ ဈေးနှုန်းက 20 ထက်ကြီးတဲ့ records တွေကိုဆွဲထုတ်ပါမယ်။ 91 | 92 | ``` 93 | SELECT product_name, stock_quantity, price 94 | FROM products 95 | WHERE stock_quantity < 50 AND price > 20; 96 | ``` 97 | ![DQL6](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dql/dql6.png) 98 | - 99 | 100 | ### % (Find) 101 | ဒီတစ်ခါတော့ `product_name` မှာ `Smart` ဆိုတဲ့ value ပါတဲ့ records တွေကိုဆွဲထုတ်ပါမယ်။
102 | keyword နဲ့တိုက်ပီးရှာချင်တယ်ဆိုရင် `%` sign ကိုအသုံးပြုပါတယ်။ 103 | 104 | ``` 105 | SELECT product_name, category 106 | FROM products 107 | WHERE product_name LIKE '%Smart%'; 108 | ``` 109 | 110 | `WHERE column_name LIKE 'abc%'`
111 | % sign ကနောက်မှာ value ကရှေ့မှာဆို abc နဲ့စတဲ့ values ရှာမယ်။
112 | `WHERE column_name LIKE '%a' `
113 | % sign ကရှေ့မှာ value ကနောက်မှာဆို abc နဲ့ဆုံးတဲ့ values ရှာမယ်။
114 | `WHERE column_name LIKE '%abc%' `
115 | % sign ကိုရှေ့နောက်နှစ်ခုလုံးကပ်ထားမယ်ဆိုနေရာမရွေးဘဲရှာမယ်။ 116 | 117 | ![DQL7](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dql/dql7.png) 118 | - 119 | 120 | ### NULL 121 | `supplier` တန်ဖိုးက `NULL` ဖြစ်နေ (မရှိနေ)တဲ့ records တွေကိုဆွဲထုတ်ကြည့်ပါမယ်။ 122 | 123 | ``` 124 | SELECT product_name, supplier 125 | FROM products 126 | WHERE supplier IS NULL; 127 | ``` 128 | 129 | ![DQL8](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dql/dql8.png) 130 | - 131 | 132 | ### BETWEEN AND 133 | Range တန်ဖိုးတွေဆက်ဆွဲထုတ်ကြည့်ရအောင်၊ ဘယ်တန်ဖိုးကနေ ဘယ်တန်ဖိုးအထိဆိုတာမျိုးပေါ့။
134 | 135 | `WHERE` နောက်မှာ `BETWEEN` နဲ့ `AND` keyword ကိုလိုက်ပြီးအသုံးပြုနိုင်ပါတယ်။
136 | `BETWEEN` နောက်မှာအစတန်ဖိုး၊ `AND` နောက်မှာအဆုံးတန်ဖိုးထည့်ပါမယ်။ 137 | 138 | ``` 139 | SELECT product_name, price 140 | FROM products 141 | WHERE price BETWEEN 50 AND 100; 142 | ``` 143 | 144 | ![DQL9](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dql/dql9.png) 145 | - 146 | 147 | ### IN 148 | အပေါ်မှာတုန်းကတူတဲ့ value ဆိုချင်ရင် `=` ဆိုတဲ့ sign ကိုအသုံးပြုခဲ့တယ်။
149 | `=` က value တစ်ခုပဲ assign လုပ်ချင်ပေမယ့် value တစ်ခုထက်ပိုပြီးထည့်သုံးချင်တဲ့အခါ `IN` ဆိုတဲ့ keyword ကိုပြောင်းသုံးရပါမယ်။
150 | 151 | `category` column က `Clothing` ဒါမှမဟုတ် `Accessories` ဖြစ်တဲ့ records တွေကိုဆွဲထုတ်ကြည့်ပါမယ်။ 152 | ``` 153 | SELECT product_name, category 154 | FROM products 155 | WHERE category IN ('Clothing', 'Accessories'); 156 | ``` 157 | 158 | ![DQL10](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dql/dql10.png) 159 | - 160 | 161 | ### NOT IN 162 | `IN` ရဲ့ပြောင်းပြန် `NOT IN` ကိုသုံးလိုက်မယ်ဆိုရင်တော့အဲ့ဒီ value တွေမပါတဲ့ records တွေကိုဆွဲထုတ်ပေးပါလိမ့်မယ်။ 163 | အောက်က screenshot မှာ result ကိုကြည့်နိုင်ပါတယ်။ 164 | 165 | ![DQL11](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dql/dql11.png) 166 | - 167 | 168 | ### NOT 169 | value ကတစ်ခုတည်းဆိုရင်တော့ `NOT IN` ကိုမသုံးဘဲ `NOT` ဆိုတဲ့ keyword တစ်ခုတည်းနဲ့လည်းအသုံးပြုနိုင်ပါတယ်။
170 | အောက်မှာဆိုရင် `category` က `Furniture` မဟုတ်တဲ့ records တွေကိုဆွဲထုတ်ထားတာဖြစ်ပါတယ်။ 171 | 172 | ``` 173 | SELECT product_name, category 174 | FROM products 175 | WHERE NOT category = 'Furniture'; 176 | ``` 177 | 178 | ![DQL12](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/dql/dql12.png) 179 | - 180 | 181 | DQL ရဲ့သဘောက data တွေကိုမိမိလိုချင်သလိုဆွဲထုတ်နိုင်ဖို့ပါပဲ၊ ဒီလိုဆွဲထုတ်ဖို့အတွက် SELECT နဲ့ WHERE ကဘယ်လောက်ထိအရေးပါလဲဆိုတာအထက်က queries တွေကိုကြည့်ရင်မြင်နိုင်ပါတယ်။
အခု article မှာတော့ DQL သဘောပေါ်လွင်အောင် ရိုးရှင်းတဲ့ query တွေကိုပဲအသုံးပြုထားပါသေးတယ်။
နောက်ပိုင်းမှာ advance ဖြစ်တဲ့ query တွေနဲ့ data ဆွဲထုတ်ပုံတွေကိုလည်းဆက်လက်ရေးသားပေးပါမယ်။ 182 | -------------------------------------------------------------------------------- /environment_setup.md: -------------------------------------------------------------------------------- 1 | # Environment Setup 2 | SQL အသုံးပြုဖို့အတွက် MySQL DBMS ကိုအသုံးပြုသွားကြပါမယ်။ 3 | 4 | ဒီ article မှာတော့ MySQL ကို Window, macOS, Linux system တွေမှာ installation လုပ်ဖို့အတွက် 5 | screenshots တွေနဲ့တကွ guide လုပ်ပေးသွားပါမယ်။ 6 | 7 | ## Window 8 | MySQL installation url ကိုသွားလိုက်ပါမယ်။ 9 | 10 | https://dev.mysql.com/downloads/installer/ 11 | 12 | ကိုယ့် system နဲ့ကိုက်ညီတဲ့ download option ကိုရွေးပါ။ 13 | 14 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window1.png)
15 | 16 | no thanks, just start my download ကိုနှိပ်ပြီး download ချပါမယ်။ 17 | 18 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window2.PNG)
19 | 20 | exe file ကို double click လုပ်ပြီး installation ကိုစတင်ပါမယ်။ 21 | 22 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window3.PNG)
23 | 24 | developer default ကိုရွေးပီး next နှိပ်ပါမယ်။ 25 | 26 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window4.png)
27 | 28 | 29 | Path ကိုရွေးပြီး next နှိပ်ပါမယ်။ 30 | 31 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window5.png)
32 | 33 | Execute ကိုနှိပ်ပြီး install စပါမယ်။ 34 | 35 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window6.png)
36 | 37 | Next နှိပ်ပါမယ်။ 38 | 39 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window7.png)
40 | 41 | Next နှိပ်ပါမယ်။ 42 | 43 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window8.png)
44 | 45 | Setting ကိုစစ်ပြီး Next နှိပ်ပါမယ်။ 46 | 47 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window9.png)
48 | 49 | legacy authentication method ကိုရွေးပြီး Next နှိပ်ပါမယ်။ အကယ်လို့ local environment မဟုတ်ဘဲ production environment တွေမှာဆိုရင်တော့ strong password option မျိုးကိုရွေးသင့်ပါတယ်။ local ကိုယ့်စက်ထဲမှာတော့ကြိုက်တာရွေးထည့်ထားနိုင်ပါတယ်။
50 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window10.png)
51 | 52 | Password ထည့်ပြီး Next နှိပ်ပါမယ်။ 53 | 54 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window11.png)
55 | 56 | Next နှိပ်ပါမယ်။ 57 | 58 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window12.png)
59 | 60 | Full access grant လုပ်ပြီး Next နှိပ်ပါမယ်။ 61 | 62 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window13.png)
63 | 64 | Configuration တွေ applyလုပ်ဖို့အတွက် execute ကိုနှိပ်ပါမယ်။ 65 | 66 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window14.png)
67 | 68 | Finish ကိုနှိပ်ပါမယ်။ 69 | 70 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window15.png)
71 | 72 | Product configurationsတွေထပ်လုပ်ဖို့အတွက် next ကိုနှိပ်ပါမယ်။ 73 | 74 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window16.png)
75 | 76 | Finish ကိုနှိပ်ပါမယ်။ 77 | 78 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window17.png)
79 | 80 | Samples configuration အတွက် next ကိုနှိပ်ပါမယ်။ 81 | 82 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window18.png)
83 | 84 | Username, password ထည့်ပြီး check ကိုနှိပ်ပါမယ်။ အဆင်ပြေတယ်ဆိုရင် next ကိုနှိပ်ပါမယ်။ 85 | 86 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window19.png)
87 | 88 | Setup ပြီးပါပြီ၊ next ကိုနှိပ်ပါမယ်။ 89 | 90 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window20.png)
91 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window21.png)
92 | 93 | Finish ကိုနှိပ်ပါမယ်။ 94 | 95 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window22.png)
96 | 97 | Start menu ကနေ MySQL 8.0 command line client ဆိုပြီးရိုက်ရှာပြီးဖွင့်လိုက်ပါမယ်။ 98 | 99 | အရှေ့မှာထည့်ခဲ့တဲ့ password ကိုဖြည့်လိုက်မယ်ဆို MySQL အသုံးပြုနိုင်ပါပြီ။ 100 | 101 | show databases လို့ရိုက်ကြည့်ပြီး database list ကို checkup လုပ်ကြည့်ထားနိုင်ပါတယ်။ 102 | 103 | ![Win Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/win/window23.png)
104 | 105 | 106 | ## macOS 107 | Download link ကနေမှတစ်ဆင့် macOS ကိုရွေးလိုက်ပါ။ 108 | 109 | ကိုယ့်ရဲ့ macOS system ကိုအောက်ပါအတိုင်းစစ်နိုင်ပါတယ်။ 110 | 111 | apple icon ကနေမှ about this mac ကိုရွေး System Report ကိုနှိပ်လိုက်မယ်ဆို system report ကိုမြင်ရမှာဖြစ်ပါတယ်။ 112 | 113 | ![Mac Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/mac/mac1.png)
114 | 115 | no thanks, just start my download ကိုနှိပ်ပြီး installer ကို download ချနိုင်ပါတယ်။ 116 | 117 | ![Mac Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/mac/mac2.png)
118 | 119 | Double click လုပ်ပြီး installation ကိုစတင်ပါမယ်။ 120 | 121 | ![Mac Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/mac/mac3.png)
122 | 123 | Allow ကိုနှိပ်ပါမယ်။ 124 | 125 | ![Mac Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/mac/mac4.png)
126 | 127 | Continue ကိုနှိပ်ပါမယ်။ 128 | 129 | ![Mac Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/mac/mac5.png)
130 | 131 | License agree လုပ်ပါမယ်။ 132 | 133 | ![Mac Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/mac/mac6.png)
134 | 135 | use legacy password ကိုရွေးပြီး next ကိုနှိပ်ပါမယ်။ 136 | local environment ကိုယ့်စက်ထဲမှာတော့ကြိုက်တာရွေးနိုင်ပေမယ့် production environment လိုမျိုးမှာ strong password option မျိုးကိုရွေးသင့်ပါတယ်။ 137 | 138 | ![Mac Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/mac/mac7.png)
139 | 140 | Password ရိုက်ထည့်ပါ။ 141 | 142 | ![Mac Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/mac/mac8.png)
143 | 144 | Installation ပြီးပါပြီ၊ close ကိုနှိပ်ပါမယ်။ 145 | 146 | ![Mac Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/mac/mac9.png)
147 | 148 | Terminal ဖွင့်ပြီး 149 | 150 | `mysql –-version` 151 | 152 | လို့ရိုက်ကြည့်လိုက်မယ်ဆို MySQL version ကိုမြင်ရပါမယ်။ 153 | 154 | `mysql -u root -p ` 155 | 156 | ရိုက်ပြီး MySQL ကို login ဝင်ကြည့်ပါမယ်။ 157 | 158 | Password ရိုက်ထည့်လိုက်မယ်ဆို MySQL အသုံးပြုနိုင်ပါပြီ။ 159 | 160 | ![Mac Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/mac/mac10.png)
161 | 162 | ## Linux 163 | Packages list ကိုအရင် update လုပ်ပါမယ်။ 164 | 165 | `sudo apt update` 166 | 167 | ![Linux Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/linux/linux1.PNG)
168 | 169 | mysql-server သွင်းပါမယ်။ 170 | 171 | `sudo apt install mysql-server` 172 | 173 | ![Linux Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/linux/linux2.PNG)
174 | 175 | သွင်းပြီးတဲ့အခါ MySQL version ကိုစစ်ကြည့်ပါမယ်။ version ပေါ်လာရင်သွင်းတာအောင်မြင်ပါတယ်။ 176 | 177 | `mysql --version` 178 | 179 | ![Linux Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/linux/linux3.PNG)
180 | 181 | 182 | MySQL ကို login ဝင်ကြည့်ပါမယ်။ လောလောဆယ်တော့ password မရှိသေးတော့ ဒီအတိုင်းဝင်သွားပါလိမ့်မယ်။ 183 | 184 | `mysql -uroot` 185 | 186 | ![Linux Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/linux/linux4.PNG)
187 | 188 | MySQL shell ထဲရောက်ပါပြီ။ password ထည့်ပါမယ်။ 189 | 190 | Password ကိုတော့ ‘password’ လို့ပဲပေးလိုက်ပါတယ်၊ ကြိုက်တာပေးလို့ရပါတယ်၊ ၈လုံးတော့ရှိဖို့လိုပါတယ်။ 191 | 192 | `ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password by 'password'` 193 | 194 | ![Linux Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/linux/linux5.PNG)
195 | 196 | MySQL shell ထဲကနေ `exit` လို့ရိုက်ပြီးထွက်လိုက်ပါတယ်။ 197 | 198 | `mysql -u root -p` 199 | 200 | လို့ရိုက်ပြီး password အသစ်နဲ့ Login ပြန်ဝင်ကြည့်ပါမယ်။ 201 | 202 | ![Linux Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/linux/linux6.PNG)
203 | 204 | `show databases` လို့ရိုက်ပြီး database list check လုပ်ကြည့်ပါမယ်။ 205 | 206 | ![Linux Installation](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/linux/linux7.PNG)
207 | -------------------------------------------------------------------------------- /erd.md: -------------------------------------------------------------------------------- 1 | ## Entity Relationship Diagram 2 | 3 | ဒီ article series လေးရဲ့နောက်ဆုံးအပိုင်းအဖြစ် ERD (Entity Relationship Diagram) တစ်ခုတည်ဆောက်တဲ့ပုံစံလေးကိုပြောပြပေးသွားချင်ပါတယ်။ 4 | 5 | Database တစ်ခုကို design ချတော့မယ်ဆိုရင် ERD ကအရေးပါတဲ့အခန်းကဏ္ဍတစ်ခုအဖြစ်ပါဝင်ပါတယ်။ အကြမ်းဖျင်းရှင်းပြရမယ်ဆိုရင် ERD ဆိုတာ Database တစ်ခုမှာရှိနိုင်တဲ့ entities တွေရဲ့ ဆက်နွယ်မှုပုံစံကိုဖော်ပြဖို့အတွက်အဓိကအသုံးပြုတာဖြစ်ပါတယ်။ အောက်မှာ components တစ်ခုခြင်းဆီအတွက်အသေးစိတ်ထပ်ပြောပြပေးသွားပါမယ်။ 6 | 7 | #### Entities 8 | Entities ဆိုတာကတော့ object တစ်ခု၊ solid concept တစ်ခုလို့သတ်မှတ်နိုင်ပါတယ်။ ဥပမာ E-commerce project တစ်ခုမှာဆိုရှိနိုင်တဲ့ entities တွေက `customer` `products` `orders` အစရှိသဖြင့်ပါဝင်နိုင်ပါတယ်။ 9 | 10 | #### Attributes 11 | Entity ထဲမှာပါတဲ့ properties တွေကို attributes လို့သတ်မှတ်နိုင်ပါတယ်။ ဥပမာ `customer` entity မှာဆို `customer_id, name, email` အစရှိသဖြင့် attributes တွေပါဝင်နိုင်ပါတယ်။ 12 | 13 | #### Relationships 14 | Entities တွေတစ်ခုနှင့်တစ်ခုဆက်နွယ်မှုကိုတော့ relationship လို့ခေါ်ဆိုပြီး relationship ပုံစံတွေကတော့ one-to-one, one-to-many, many-to-many ရှိတတ်ပါတယ်။ 15 | 16 | #### Primary Key 17 | Entity တစ်ခုမှာ unique ဖြစ်နိုင်တဲ့ attribute တစ်ခု သို့ attributes အစုကို Primary key အဖြစ်သတ်မှတ်ပါတယ်။ 18 | 19 | #### Foreign Key 20 | Entities တွေတစ်ခုနှင့်တစ်ခုချိတ်ဆက်ဖို့အတွက် အခြား entity ရဲ့ primary ကို reference လုပ်တဲ့နေရာမှာအသုံးပြုပါတယ်။ 21 | 22 | --- 23 | 24 | ERD နဲ့ပတ်သတ်လာလို့ components တစ်ခုခြင်းဆီကိုခွဲထုတ်ပြီးရှင်းပြလိုက်ပေမယ့် အားလုံးကိုရှေ့က articles တွေမှာဖော်ပြဖူးတဲ့အတွက်နားလည်ရလွယ်ကူမယ်လို့ထင်ပါတယ်။ 25 | 26 | ERD ရဲ့ components တွေကိုသိသွားပြီဆိုတော့တစ်လက်စတည်း ERD တစ်ခုဆွဲကြည့်သွားကြပါမယ်။ ERD တစ်ခုဆွဲတော့မယ်ဆို 27 | 1. အရင်ဆုံးပါဝင်တဲ့ entities တွေကိုသတ်မှတ်ဖို့လိုပါတယ်။ အထက်မှာကျနော်ပြောခဲ့တဲ့ e-commerce system တစ်ခုမှာဆို `customers, products, orders, order_details` တွေပါဝင်နိုင်ပါတယ်။ အခြားသော entities တွေလည်းအများကြီးရှိနိုင်ပါသေးတယ်။ ဒါပေမယ့်ဒီအပိုင်းမှာတော့ learning purpose ဖြစ်တဲ့အတွက်လက်ရှိ entities 4 ခုနဲ့ပဲဆွဲကြည့်ကြပါမယ်။ 28 | 2. Entity တစ်ခုခြင်းဆီအတွက် attributes တွေသတ်မှတ်ကြပါမယ်။ 29 | I. `customers` 30 | - customer_id (Primary Key) 31 | - name 32 | - email 33 | - address 34 | 35 | II. `products` 36 | - product_id (Primary Key) 37 | - name 38 | - price 39 | - stock_left 40 | 41 | III. `orders` 42 | - order_id (Primary Key) 43 | - order_date 44 | - customer_id (Foreign Key) 45 | 46 | IV. `order_details` 47 | - order_detail_id (Primary Key) 48 | - order_id (Foreign Key) 49 | - product _id (Foreign Key) 50 | - quantity 51 | 52 | ကျနော်ကတော့ `order` နဲ့ `order_details` table ကိုခွဲပြီးတော့သိမ်းလေ့ရှိပါတယ်။ မိမိအဆင်ပြေသလိုတွဲပြီးသုံးမယ်ဆိုလည်းရပါတယ်။ Data amount များလာရင်တော့ခွဲပြီးသိမ်းတဲ့ပုံစံက `performance` အရရော `structure` အရရောပိုပြီးကောင်းစေပါတယ်။ 53 | 54 | 3. Entities တွေရဲ့ဆက်နွယ်မှုပုံစံတွေကိုသတ်မှတ်ကြပါမယ်။ 55 | - Customer တစ်ယောက်ဟာ orders တွေအများကြီးတင်နိုင်တယ်။ 56 | - Order တစ်ခုမှာလည်း order_details တွေထပ်ရှိနိုင်တယ်။ 57 | - Product တစ်ခုကလည်း order_details တွေထဲရှိနိုင်ပါတယ်။ 58 | 59 | Entities, attributes တွေနဲ့ relationships တွေသတ်မှတ်ပြီးပြီဆိုမိမိနှစ်သက်ရာ drawing tool နဲ့ ERD ကိုဆွဲချနိုင်ပါပြီ။ အောက်ကပုံကတော့ကျနော်ဆွဲထားတဲ့ပုံလေးဖြစ်ပါတယ်။ 60 | 61 | ![ERD](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/erd.png) 62 | 63 | စနစ်ကျတဲ့ database တစ်လုံးတည်ဆောက်ရန်အတွက် ERD ဆွဲကြည့်ခြင်းဟာအလွန်အရေးပါပါတယ်။ Entities, attributes နဲ့ relationships တွေသတ်မှတ်ခြင်းအားဖြင့် တည်ဆောက်နေတဲ့ application ရဲ့လိုအပ်တဲ့ data structure ကိုထောက်ပံ့ပေးနိုင်မှာလည်းဖြစ်ပါတယ်။ 64 | 65 | -------------------------------------------------------------------------------- /index.md: -------------------------------------------------------------------------------- 1 | ## Indexing 2 | အရင်ဆုံး Indexing ဆိုတာဘာအတွက်လိုတာလဲနဲ့ဘယ်လိုအလုပ်လုပ်တယ်ဆိုတာကို theory introduction လုပ်ပေးပါရစေ။ ပြီးရင်လက်တွေ့ query run ကြည့်ပြီးကွဲပြားချက်ကိုဆန်းစစ်ကြည့်ပါမယ်။ 3 | 4 | SELECT * FROM users WHERE name = ‘John’ 5 | 6 | Database ထဲမှာ ဒီလို query တစ်ကြောင်း run လိုက်တဲ့အချိန်မှာ users table ထဲက name column မှာ John ဆိုတဲ့ value ရှိတဲ့ records တွေပြန်ပေးပါတယ်။ ဒီလိုပြန်ပေးဖို့အတွက် users table ထဲမှာရှိတဲ့ row အားလုံးကို query ကလိုက်ကြည့်ရပါတယ်၊ ဒါကို Full table scan, table တစ်ခုလုံးကိုလိုက်ရှာရတယ်လို့လည်းဆိုပါတယ်။ 7 | 8 | Index ဆိုတာကတော့ Full table scan, table တစ်ခုလုံးကို scan/lookup လုပ်စရာမလိုတော့ဘဲနဲ့ လိုအပ်တဲ့ scan operation ကိုသာလုပ်ပြီး လိုချင်တဲ့ results တွေကိုရအောင် လုပ်ပေးနိုင်တဲ့ data structure တစ်ခုဖြစ်ပါတယ်။ တစ်နည်းအားဖြင့် query efficiency (read) ကိုမြှင့်ပေးနိုင်တဲ့ အရာတစ်ခုလို့ဆိုနိုင်ပါတယ်။ 9 | 10 | ပုံမှန်အားဖြင့် data တွေသိမ်းထားတဲ့ table တွေက order စီထားခြင်းမရှိပါဘူး၊ ဒီအတွက်ကြောင့်လည်း condition တစ်ခုကို lookup လုပ်တဲ့အချိန်မှာ table ထဲမှာရှိတဲ့ record အားလုံးကိုဖတ်ရတယ်၊ Linear lookup ပုံစံမျိုးအလုပ်လုပ်ရပါတယ်။ data ပမာဏနည်းသေးတဲ့အချိန်မှာ အဆင်ပြေနေသေးမယ့် data ပမာဏများလာတဲ့အချိန်မှာတော့ query execution time ကပိုပြီးကြာလာနိုင်ပါတယ်၊ ဒါမှမဟုတ် table တစ်ခုနဲ့တစ်ခု Join ပြီး lookup လုပ်တဲ့အချိန်တွေမှာလည်း နှစ်ဆလောက်ပိုပြီးကြာသွားနိုင်ပါတယ်။ 11 | 12 | အလွယ်ကူဆုံးဥပမာတစ်ခုပေးရရင် အကယ်လို့သိမ်းထားတဲ့ data တွေသာ order အစီအစဉ်တကျစီထားနိုင်မယ်ဆို အပေါ်က John ဆိုတဲ့ value ကိုရှာတဲ့အချိန်မှာ ပုံမှန်အတိုင်း full table scan လုပ်ရပေမယ့် first alphabet က J ကိုကျော်သွားတဲ့အချိန်မှာ scan ထပ်ပြီးလုပ်စရာမလိုတော့တဲ့အတွက် scan လုပ်ရမယ့် operation ကို ပမာဏတစ်ခုအထိ လျော့ချနိုင်သွားမှာဖြစ်ပါတယ် (This’s just a metaphor)။ 13 | 14 | ဒါပေမယ့်တစ်ကယ်တမ်းမှာတော့ table တွေက order စီထားခြင်းမရှိဘူး၊ ကျနော်တို့ရှာချင်တဲ့ query condition တွေကလည်း dynamic ဖြစ်တဲ့အတွက် scan operation မလုပ်ခင်မှာ table column တွေကိုလည်းအဲ့အတိုင်းလိုက်ပြောင်းပြီး order လိုက်စီပေးဖို့မလွယ်ကူပါဘူး။ ဒီနေရာမှာ index ဆိုတဲ့အရာကို သုံးနိုင်ပါတယ်။ Index က ဘာလုပ်ပေးလဲဆိုတော့ data structure တစ်ခုဖန်တီးပေးလိုက်ပါတယ်၊ များသောအားဖြင့် Binary Tree structure (တစ်ခြားသော structure တွေလည်းဖြစ်နိုင်ပါတယ်)။ B-Tree အကြောင်းမသိဘူးဆိုရင် အရင်ရှာဖတ်ကြည့်ဖို့တိုက်တွန်းပါတယ်။ အဓိကရည်ရွယ်ချက်ကတော့ sorting/order လုပ်ထားတဲ့ structure တစ်ခုရလာဖို့ရယ်၊ searching/scanning quality ကိုလည်းအများကြီးကောင်းမွန်သွားစေမှာဖြစ်ပါတယ်။ 15 | 16 | Index တစ်ခု create လုပ်ပြီဆိုရင်ဘယ် column ကို index ထားမလဲဆိုတာ ပြောပေးရပါတယ်။ ဥပမာကိုယ်က name ဆိုတဲ့ column ကိုပဲ index လုပ်မယ်ဆိုရင် table ထဲမှာရှိတဲ့ name မဟုတ်တဲ့တစ်ခြားသော column တွေကတော့ index ဖြစ်မှာမဟုတ်ပါဘူး။ name ဆိုတဲ့ column အတွက်ပဲ index ဖန်တီးပေးသွားမှာဖြစ်ပါတယ်။ 17 | 18 | Index ဘယ်လိုဖန်တီးသွားလဲဆိုတော့ index လုပ်ချင်တဲ့ column ကို key အဖြစ်နဲ့ value နေရာမှာ table ထဲမှာရှိတဲ့ record ကိုဆီကိုသွားနိုင်မယ့် reference pointer တစ်ခုသိမ်းထားလိုက်ပါတယ်။ ဆိုတော့ Index structure ထဲမှာ key က index လုပ်ထားတဲ့ column, value နေရာမှာ record reference pointer. Structure ကလည်း sorting စီထားပြီးသားဖြစ်မယ်။ query condition တစ်ခု run လိုက်ပြီဆို table ကိုသွားပြီး full scan မလုပ်တော့ဘဲ ခုနက index structure ထဲမှာပဲ သုံးထားတဲ့ structure အတိုင်း lookup လုပ်မယ် (လက်ရှိမှာတော့ B-tree) ၊ key ရလာပြီဆို reference pointer ကနေမှတစ်ဆင့် တစ်ကယ့် record ကိုသွားပြီးယူလိုက်ရုံပဲ၊ ဒါကြောင့်မို့လို့ lookup လုပ်တဲ့နေရာမှာ linear scanning မဟုတ်တော့ဘဲနဲ့ သုံးထားတဲ့ structure အတိုင်း efficiency ကောင်းကောင်းနဲ့ lookup လုပ်သွားနိုင်မှာဖြစ်ပါတယ်။ 19 | 20 | ဒါပေမယ့်ကိုယ့်ဘက်ကပေးရမယ့် cost ကလည်းရှိတယ်။ Index တွေအတွက် space ပြန်ပေးရတယ်၊ key , value ပုံစံနဲ့ sorted structure တစ်ခုဖန်တီးရတာကိုး။ နောက်တစ်ခုက lookup/read operation တွေမှာ efficiency ကောင်းပေမယ့် row အသစ်တစ်ခု insert လုပ်တဲ့ operation မှာ index ထောက်ထားတဲ့အတွက် index ပါဖန်တီးပေးဖို့လိုတဲ့အတွက်ကြောင့် ပုံမှန်ထက်တော့ ပိုနှေးသွားမှာဖြစ်ပါတယ်။ update, delete တွေမှာလည်းသဘောတရားကအတူတူပါပဲ။ ဒီလိုပဲ တစ်ခုလိုချင် တစ်ခုပြန်ပေးရတဲ့ trade-off သဘောတရားကတော့ အမြဲရှိတတ်ပါတယ်။ 21 | 22 | Theory ကတော့ဒီလောက်ဆိုလုံလောက်ပြီလို့ထင်ပါတယ်၊ လက်တွေ့စမ်းပြီးလုပ်ကြည့်ပါမယ်။ 23 | 24 | `employees` ဆိုတဲ့ table တစ်လုံးဆောက်လိုက်ပါမယ်။ အဆင်ပြေတဲ့ database ကိုအသုံးပြုနိုင်ပါတယ်။ 25 | 26 | ``` 27 | CREATE TABLE employees ( 28 | employee_id INT PRIMARY KEY, 29 | name VARCHAR(50), 30 | department_id INT 31 | ); 32 | ``` 33 | ![index](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/index/index1.png) 34 | 35 | --- 36 | ပြီးရင် data row 100,000 ကို program ရေးပြီးထည့်လိုက်ပါမယ်။ လက်ရှိဒီ program ကိုနားလည်စရာမလိုသေးပါဘူး၊ data ထည့်ပြီး test လုပ်ကြည့်ဖို့အတွက်လောက်ပါပဲ။ ပါဝင်တဲ့ keyword တစ်ခုခြင်းဆီကို မိမိဘာသာ research လုပ်ကြည့်ပြီး program ကိုနားလည်အောင်ကြိုးစားကြည့်လို့လည်းရပါတယ်။ 37 | 38 | ``` 39 | DELIMITER $$ 40 | CREATE PROCEDURE generate_sample_data() 41 | BEGIN 42 | DECLARE i INT DEFAULT 1; 43 | WHILE i <= 100000 DO 44 | INSERT INTO employees (employee_id, name, department_id) 45 | VALUES (i, CONCAT('Employee', i), FLOOR(RAND() * 3) + 1); 46 | SET i = i + 1; 47 | END WHILE; 48 | END $$ 49 | DELIMITER ; 50 | 51 | CALL generate_sample_data(); 52 | ``` 53 | > Row 100,000 ဖြစ်တဲ့အတွက် program run တာပြီးအောင်အနည်းငယ်တော့စောင့်ရပါမယ်။ 54 | 55 | ![index](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/index/index2.png) 56 | 57 | --- 58 | 59 | `select count(*)` နဲ့အောက်ပါအတိုင်း row count ကိုစစ်ကြည့်လို့ရပါတယ်။ 60 | ![index](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/index/index3.png) 61 | 62 | --- 63 | အရင်ဆုံး query performance ကိုစစ်နိုင်ဖို့အတွက် profile ကို on ထားလိုက်ပါမယ်။ `SHOW PROFILES` နဲ့ပြန်စစ်ကြည့်မယ်ဆို run ခဲ့တဲ့ query list ရဲ့ Profiles တွေကိုတွေ့နိုင်ပါတယ်။ 64 | 65 | ![index](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/index/index4.png) 66 | 67 | --- 68 | 69 | Index create မလုပ်ခင်မှာ query တစ်ကြောင်းအရင် run ကြည့်ပါမယ်။ ရိုးရိုးရှင်းရှင်း employees table ထဲက လိုချင်တဲ့ name ကိုလှမ်းဆွဲထုတ်ကြည့်ပါမယ်။ 70 | 71 | ``` 72 | SELECT * FROM employees WHERE name = “Employee500” 73 | ``` 74 | ပြီးတာနဲ့ `SHOW PROFILES` နဲ့ပါတစ်ခါတည်းစစ်ကြည့်လိုက်မယ်ဆို QUERY ID, Duration တွေကိုတွေ့နိုင်ပါတယ်။ 75 | 76 | ![index](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/index/index5.png) 77 | 78 | --- 79 | နောက်တစ်ဆင့်အနေနဲ့ `employees` table ထဲက name အပေါ်မှာ `index` တစ်ခုဖန်တီးသွားပါမယ်။ ပြီးရင် ခုနက run ခဲ့တဲ့ query ကို ပြန် run ကြည့်ပါမယ်။ index ကြောင့် query performance ကတက်လာသင့်ပါတယ်။ 80 | 81 | ``` 82 | CREATE INDEX idx_employee_name ON employees(name); 83 | ``` 84 | 85 | ![index](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/index/index6.png) 86 | 87 | --- 88 | 89 | ဒီ query ကိုပြန် run ကြည့်ပြီး `SHOW PROFILES` နဲ့စစ်ကြည့်ပါမယ်။ 90 | ``` 91 | SELECT * FROM employees WHERE name = “Employee500” 92 | ``` 93 | 94 | ![index](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/index/index7.png) 95 | 96 | --- 97 | 98 | Duration မှာ index တည်ဆောက်ခဲ့ပြီးမှ run ခဲ့တဲ့ query ကသိသိသာသာနည်းသွားတာကိုကြည့်ခြင်းအားဖြင့် query performance တက်လာကိုမြင်နိုင်ပါတယ်။ 99 | Row 100,000 နဲ့ simple WHERE query ကိုပဲဥပမာပြထားပေမယ့် real world မှာဒီထက်ပိုများတဲ့ data တွေနဲ့ပိုရှုပ်ထွေးတဲ့ query တွေမှာဆိုသိသိသာသာခြားနားသွားမှာဖြစ်ပါတယ်။ 100 | 101 | နိဂုံးချုပ်ရမယ်ဆို Indexing ဟာ query performance နဲ့ overall efficiency ကိုသိသာစွာမြှင့်တင်ပေးနိုင်ပါတယ်။ သို့ပေမယ့်အပေါ်မှာပြောပြခဲ့တဲ့အတိုင်း trade off တစ်ချို့ရှိပါတယ်။ over-indexing မဖြစ်အောင် မကြာခဏအသုံးပြုလေ့ရှိတဲ့ columns တွေကိုပဲ index ထည့်မယ်၊ ရေရှည်အားဖြင့် index တွေကို monitor & maintain လုပ်ခြင်းအားဖြင့်သင့်လျှော်စွာအသုံးပြုသင့်ကြောင်းကိုလည်းသတိချပ်ထားသင့်ပါတယ်။ 102 | 103 | 104 | 105 | -------------------------------------------------------------------------------- /joins.md: -------------------------------------------------------------------------------- 1 | ## SQL Joins 2 | 3 | Relationship အပိုင်းမှာ table တွေကိုချိတ်ဆက်ပြီး data တွေယူတယ်လို့ပြောခဲ့ပါတယ်။ ဒီလိုချိတ်ဆက်ဖို့အတွက် `JOIN` ဆိုတဲ့ keyword ကိုသုံးပြီး query တွေရေးပါတယ်။ အခုအပိုင်းမှာတော့ အသုံးများတဲ့ JOIN အမျိုးအစားတွေကိုရှင်းပြရင်း JOIN အသုံးပြုနည်းကိုပါ query တွေ run ကြည့်သွားရင်းလေ့လာသွားကြပါမယ်။ 4 | 5 | ဒါကတော့ JOIN query ရဲ့ schema ပဲဖြစ်ပါတယ်။ 6 | ``` 7 | SELECT column1, column2, ... 8 | FROM table1 9 | INNER JOIN table2 ON table1.column_name = table2.column_name; 10 | ``` 11 | 12 | `ON table1.column_name = table2.column_name` ဆိုတာကတော့ table နှစ်လုံးရဲ့ `primary key`, `foreign key` ကိုချိတ်ဆက်မယ့် condition တစ်ခုကိုဖော်ပြတဲ့သဘောဖြစ်ပါတယ်။ 13 | 14 | `INNER JOIN` ဆိုတာကတော့အဲ့ဒီ `condition` အပေါ်မှာ match ဖြစ်တဲ့ records သီးသန့်ကိုပဲလိုချင်တယ်လို့ဆိုတာပါ။ `INNER JOIN` က JOIN အမျိုးအစားတစ်ခုပဲဖြစ်ပါတယ်။ 15 | 16 | အောက်မှာတစ်ခြားသော `JOIN` တွေကိုဆက်ကြည့်ရင်း JOIN queries တွေကိုပိုသဘောပေါက်အောင်ကြိုးစားကြည့်ပါမယ်။ 17 | 18 | Join query တွေမရေးခင်မှာ tables တွေနဲ့ data တွေပြင်ဆင်ထားပါမယ်။ 19 | 20 | ရှိပြီးသား `students`table နဲ့ `student_details` ဆိုတဲ့ table နှစ်ခုကိုသုံးပြီးတော့ JOIN queries တွေစမ်းရေးသွားပါမယ်။ 21 | 22 | `student_details` table ဆောက်ပါမယ်၊ ရှိပြီးသားသူတွေကတော့ဆောက်စရာမလိုပါဘူး။ 23 | ``` 24 | CREATE TABLE student_details ( 25 | student_id INT PRIMARY KEY, 26 | address VARCHAR(100), 27 | FOREIGN KEY (student_id) REFERENCES students(student_id) 28 | ); 29 | ``` 30 | 31 | တစ်ခါတည်း student_id ကို `students` table ရဲ့ foreign key အဖြစ်သတ်မှတ်ထားလိုက်ပါတယ်။ 32 | 33 | `student_details`table ထဲကို data ထည့်ပါမယ်။ 34 | ``` 35 | INSERT INTO student_details (student_id, address) VALUES 36 | (1, 'Yangon, Myanmar'), 37 | (2, 'Mandalay, Myanmar'), 38 | (3, 'Naypyidaw, Myanmar'), 39 | (4, 'Bago, Myanmar'), 40 | (5, 'Magway, Myanmar'); 41 | ``` 42 | ![join](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/join/j1.png) 43 | 44 | ### Inner Join 45 | Inner Join ဆိုတာကတော့ table နှစ်လုံးထဲကမှ သတ်မှတ်လိုက်တဲ့ **condition** ပေါ်မူတည်ပြီး `match` ဖြစ်တဲ့ records တွေကိုသာ join ဖြစ်စေပါတယ်။ **condition** က match မဖြစ်ဘူးဆိုရင် records မထွက်တဲ့အခါမျိုးလည်းရှိတတ်ပါတယ်။ 46 | 47 | ![join](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/join/j2.1.png) 48 | *Image Credit : W3Schools* 49 | 50 | ဥပမာ `students`table နဲ့ `student_details` table ကို **JOIN** ပြီးတော့ data တွေကိုဆွဲထုတ်ပါမယ်။ သို့ပေမယ့် table နှစ်ခုလုံးမှာ **match** ဖြစ်တဲ့ results ကိုသာယူမယ်ဆိုရင်အောက်ကလိုမျိုးရေးနိုင်ပါတယ်။ 51 | ``` 52 | SELECT students.student_id, students.name, student_details.address FROM students INNER JOIN student_details ON students.student_id = student_details.student_id; 53 | ``` 54 | 55 | `student_details` မှာက `student_id` 1 to 5 အထိသာရှိတဲ့အတွက် table နှစ်ခုလုံးမှာ match ဖြစ်တဲ့ condition ဟာ student_id 1 to 5 ဖြစ်တဲ့ records ငါးကြောင်းသာဖြစ်ပါတယ်။ `students`table မှာရှိတဲ့ `student_id` 6,7,8 ဟာ `student_details` ထဲမှာမရှိတဲ့အတွက်ပါလာမှာမဟုတ်ပါဘူး။ 56 | 57 | ![join](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/join/j2.png) 58 | 59 | ### Left Join 60 | 61 | Left Join ကတော့ဘယ်ဘက်ခြမ်းက records အားလုံးနဲ့ ညာဘက်ခြမ်းက **match** ဖြစ်တဲ့ records တွေကိုဆွဲပေးပါတယ်၊ သို့ပေမယ့်ဘယ်ဘက်ခြမ်းက records တွေကအားလုံးပါတာဖြစ်တဲ့အတွက်ညာဘက်ခြမ်းက **match** မဖြစ်တဲ့ records တွေရဲ့ column တန်ဖိုးနေရာမှာတော့ `NULL` values တွေပါလာမှာဖြစ်ပါတယ်။ 62 | 63 | ![join](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/join/j3.1.png) 64 | *Image Credit : W3Schools* 65 | 66 | ``` 67 | SELECT students.student_id, students.name, student_details.address FROM students LEFT JOIN student_details ON students.student_id = student_details.student_id; 68 | ``` 69 | 70 | ဒီ query မှာဆို LEFT JOIN သုံးထားပြီးတော့ `Left` side table က `stuents` ဖြစ်မယ်။ `Right` side table က `student_details` ဖြစ်မယ်။ `student_details` table မှာမရှိတဲ့ `students` table က records တွေက `address` column မှာ NULL value တွေဖြစ်နေမှာဖြစ်ပါတယ်။ အောက်ကပုံနဲ့တွဲကြည့်ရင်ပိုနားလည်ပါလိမ့်မယ်။ 71 | 72 | ![join](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/join/j3.png) 73 | 74 | ### Right Join 75 | 76 | Right join ကတော့ Left join နဲ့သဘောတရားချင်းတူတူပါပဲကိုမှ `right` table က records ကအကုန်ပါမယ်၊ `left` ဘက်က **match** မဖြစ်တဲ့ records တွေကတော့ `students`table က column တွေနေရာမှာ NULL value တွေဖြစ်သွားပါမယ်။ 77 | 78 | ![join](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/join/j4.1.png) 79 | *Image Credit : W3Schools* 80 | 81 | ``` 82 | SELECT students.student_id, students.name, student_details.address FROM students RIGHT JOIN student_details ON students.student_id = student_details.student_id; 83 | ``` 84 | Result ပုံနဲ့တွဲကြည့်ရင်ပိုနားလည်သွားပါမယ်။ လက်ရှိ table ထဲမှာတော့ right table `student_details` ထဲက records တွေအားလုံး left table `students` မှာ match records ရှိနေတဲ့အတွက် NULL values မတွေ့နိုင်ပါဘူး။ `student_details` ထဲမှာ `students` table ထဲမှာမရှိတဲ့ `student_id` တစ်ခုခုနဲ့ records ဖန်တီးပြီးပြန် run ကြည့်လိုက်မယ်ဆိုမတူတဲ့ result တစ်မျိုးရပါလိမ့်မယ်၊ စမ်းပြီးလုပ်ကြည့်ပါ။ 85 | 86 | ![join](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/join/j4.png) 87 | 88 | ### Full Join 89 | 90 | Full join ကတော့အရှင်းဆုံးပြောရရင် Left join နဲ့ Right Join ကိုပေါင်းထားတဲ့သဘောပါပဲ။ အပြန်အလှန် **match** မဖြစ်တဲ့ records တွေမှာတော့ NULL values တွေဝင်သွားပါမယ်။ 91 | 92 | ![join](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/join/j5.1.png) 93 | *Image Credit : W3Schools* 94 | 95 | ကျနော်တို့အခုသုံးနေတဲ့ MySQL DBMS မှာ `FULL JOIN` ဆိုတဲ့ keyword မရှိပါဘူး။ အဲ့အတွက်ကြောင့် `UNION` ဆိုတဲ့ keyword သုံးပြီးတော့ left နဲ့ right ကိုပေါင်းလိုက်ပါတယ်။ အောက်ကနမူနာ query ကို run ကြည့်နိုင်ပါတယ်။ 96 | ``` 97 | SELECT students.student_id, students.name, student_details.address 98 | FROM students 99 | LEFT JOIN student_details ON students.student_id = student_details.student_id 100 | 101 | UNION 102 | 103 | SELECT students.student_id, students.name, student_details.address 104 | FROM students 105 | RIGHT JOIN student_details ON students.student_id = student_details.student_id 106 | WHERE students.student_id IS NULL; 107 | --- WHERE case ကမထည့်လည်းရပါတယ်။ ကျနော်ရေးတာပိုသွားတာပါ။ 108 | ``` 109 | ![join](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/join/j5.png) 110 | 111 | 112 | 113 | Full Join တွေက records တွေကိုဘယ်ညာအကုန်ပြန်ထုတ်ပေးတဲ့အတွက်ပုံမှန်ထက်ပိုပြီးနှေးပါတယ်၊ data တွေမြောက်မြားစွာသိမ်းထားတဲ့ table တွေကို `full join` လုပ်တော့မယ်ဆို **efficiency** သိသိသာသာကျစေတဲ့အတွက် ဒီတစ်ချက်ကိုတော့သတိပြုထားသင့်ပါတယ်။ 114 | 115 | Recap လုပ်ရမယ်ဆို 116 | Inner join ဆိုတာ match ဖြစ်တဲ့ records သီးသန့်။ 117 | Left join ဆိုတာ left ကအကုန်၊ right က match records သီးသန့်။ 118 | Right join ဆိုတာ right ကအကုန်၊ left က match records သီးသန့်။ 119 | Full join ဆိုတာ filter မရှိဘဲ ဘယ်ညာအကုန်။ 120 | 121 | များသောအားဖြင့် development လုပ်ပြီဆို database ထဲမှာ table relations တွေများစွာပါတတ်ပါတယ်။ Join တွေကိုနားလည်ထားမှသာမိမိလိုသလို table တွေကိုချိတ်ဆက်ပြီး data တွေကို efficiency ကောင်းကောင်းနဲ့ထုတ်သွားနိုင်မှာဖြစ်ပါတယ်။ ဒီအပိုင်းမှာ section တစ်ခုစီကို query တစ်ကြောင်းပဲရေးပြထားပါတယ်၊ ရှုပ်သွားမှာစိုးလို့ပါ။ နောက်အပိုင်းမှာ relationship type တွေအကြောင်းထပ်ရှင်းပြရင်း join queries တွေဆက်လေ့လာသွားကြပါမယ်။ 122 | 123 | -------------------------------------------------------------------------------- /normalization.md: -------------------------------------------------------------------------------- 1 | ## Normalization 2 | 3 | ဒီအပိုင်းကနေစပြီးတော့ကျနော်ထပ်ဖြည့်ချင်တဲ့ content လေးတွေထပ်ဖြည့်သွားပါမယ်။ ပြီးခဲ့တဲ့ relationship, join တွေအပိုင်းပြီးရင်အခြေခံအတွက်လုံလောက်ပြီလို့ပြောလို့ရပါတယ်။ နောက်အပိုင်းတွေကတော့ advance ဖြစ်လာတဲ့အတွက် အခေါ်အဝေါ်လေးတွေကအစဖတ်ရတာနည်းနည်းခက်နိုင်ပါတယ်။ ကျနော်တတ်နိုင်သလောက်တော့နားလည်ရလွယ်အောင်စဉ်းစားပြီးရှင်းပြပေးထားပါတယ်။ ဒီအပိုင်းတွေကိုဖတ်ရင်းနဲ့တစ်ခြားသော online က resources တွေနဲ့လည်းတွဲဖက်ပြီးပိုစဉ်းစားနိုင်ဖို့အကြံပြုပါတယ်ခင်ဗျာ။ 4 | 5 | Database ထဲမှာ data တွေများလာတဲ့အခါမှာပြန်ထုတ်ယူရတဲ့နေရာမှာကိုယ်လိုချင်တဲ့ data တွေအတိုင်းထပ်အပ်ကျဖို့ဆိုတာခက်ခဲလာနိုင်ပါတယ်။ Normalization ရဲ့အကူအညီနဲ့ဒီလိုအခက်အခဲတွေကိုကျော်လွှားနိုင်ပါတယ်။ Normalization ဟာ data redundancy (data ဆုံးရှုံးမှု) ဖြစ်နိုင်မှုကိုလျော့ချနိုင်ပြီးတော့ data integrity (data စစ်မှန်မှု) ကိုပိုမိုကောင်းမွန်လာနိုင်စေပါတယ်။ 6 | 7 | ဥပမာအားဖြင့် Normalize မလုပ်ထားတဲ့ data တွေဆို data ဆွဲထုတ်တဲ့အချိန်မှာထပ်နေတဲ့အချိန်မှာထပ်နေတဲ့ data တွေပါလာနိုင်တာမျိုး၊ data ထည့်တဲ့အချိန်မှာ attribute တွေမကိုက်လို့ထည့်မရတာမျိုး၊ ကိုယ်ဖျက်ချင်တာကတစ်မျိုး၊ attributes တွေရောယှက်ပြီးတော့ပျက်သွားတာကတစ်မျိုးတွေဖြစ်တတ်ပါတယ်။ 8 | 9 | Normalization ဆိုတာတစ်နည်းအားဖြင့် data တွေကို organize ဖြစ်အောင်လုပ်ထားတာပါပဲ။ Database ထဲမှာရှိတဲ့ tables နဲ့ columns တွေကိုသတ်မှတ်ထားတဲ့ constraints (စည်းမျဉ်း) တွေနဲ့ organize လုပ်ထားခြင်းပဲဖြစ်ပါတယ်။ 10 | 11 | ဒီဆောင်းပါးမှာ Normalization form ၆ ခုကိုရေးပေးသွားမှာဖြစ်ပါတယ်။ 12 | 13 | ### First Normal Form (1NF) 14 | 1NF မှာတော့ atomicity ဖြစ်ရမယ်။ တစ်နည်းအားဖြင့် Table တစ်လုံးထဲမှာ multi value attribute တွေမရှိရဘူး၊ column တစ်ခုက multiple value မရှိနေရဘူး။ 15 | 16 | အောက်က table ကိုနမူနာကြည့်မယ်ဆို `authors` column က value တွေကိုတစ်ခုထက်ပိုပြီးကိုင်ထားပါတယ်။ ဒါဆိုရင် atomicity မဖြစ်တော့ဘူး 1NF ပြောင်းပေးရပါမယ်။ 17 | 18 | 19 | | book_id | title | authors | genre | 20 | |---------|------------------------|-----------------------|---------------| 21 | | 1 | The Art of SQL | Jane Doe, John Smith | Database | 22 | | 2 | SQL Mastery | Jane Doe, Alice Johnson| Programming | 23 | | 3 | Query Tactics | John Smith, Alice Johnson | Database | 24 | 25 | 26 | Table ကို `books` နဲ့ `authors`နှစ်ခုအဖြစ်ခွဲပေးလိုက်ပါမယ်။ 27 | 28 | Books Table: 29 | 30 | | book_id | title | genre | 31 | |---------|------------------------|---------------| 32 | | 1 | The Art of SQL | Database | 33 | | 2 | SQL Mastery | Programming | 34 | | 3 | Query Tactics | Database | 35 | 36 | Authors Table: 37 | 38 | | book_id | author_name | 39 | |---------|--------------| 40 | | 1 | Jane Doe | 41 | | 1 | John Smith | 42 | | 2 | Jane Doe | 43 | | 2 | Alice Johnson| 44 | | 3 | John Smith | 45 | | 3 | Alice Johnson| 46 | 47 | 1NF ပြောင်းအပြီးမှာ table တိုင်းရဲ့ column တိုင်းမှာ atomic value တွေပဲရှိနေတော့ပါမယ်။ `authors` table မှာတော့ `books` table ကို reference လုပ်နိုင်အောင် `book_id`ထည့်ပေးထားလိုက်ပါတယ်။ table ကနှစ်လုံးမခွဲလည်းရပါတယ်၊ တစ်လုံးထဲမှာပဲ row တွေပြောင်းထည့်ပြီးသိမ်းခြင်းအားဖြင့်လည်း 1NF ကိုပြေလည်စေပါတယ်။ 48 | 49 | Candidate Key & Non-prime attribute 50 | 2NF ကိုဆက်မသွားခင် candidate key ဆိုတဲ့အရာတစ်ခုကိုမိတ်ဆက်ပေးချင်ပါတယ်။ Candidate key ဆိုတာကတော့ table တစ်လုံးထဲမှာ record တစ်ကြောင်းကို `unique` ဖြစ်တယ်လို့သတ်မှတ်နိုင်တဲ့ တစ်ခု သို့ တစ်ခုထက်ပိုတဲ့ columns တွေကိုဆိုလိုခြင်းဖြစ်ပါတယ်။ 51 | 52 | ![normalization](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/nor/nor1.png) 53 | Credit geekforgeek 54 | 55 | Non-prime attribute ဆိုတာကတော့ candidate keys မဟုတ်တဲ့ attribute တစ်ခုကိုဆိုလိုခြင်းဖြစ်ပါတယ်။ 56 | 57 | --- 58 | 59 | ### Second Normal Form (2NF) 60 | 61 | 2NF ဖြစ်ဖို့အတွက် table က 1NF ဖြစ်ပြီးသားဖြစ်ရပါတယ်။ 62 | နောက်တစ်ခုကတော့ partial dependency မဖြစ်ရပါဘူး။ Partial dependency ဆိုတာကိုနားလည်နိုင်ဖို့အောက်ကဥပမာကိုကြည့်နိုင်ပါတယ်။ 63 | 64 | 65 | | student_id | course_id | course_name | 66 | |------------|-----------|--------------------| 67 | | 1 | 101 | Database Fundamentals | 68 | | 2 | 102 | Advanced SQL Queries | 69 | | 3 | 103 | Data Modeling and Design | 70 | 71 | ဒီ table မှာ `student_id` `course_id` က candidate keys တွေဖြစ်နေပါတယ်။ `course_name` ကတော့ `non-prime` attribute ဖြစ်ပါတယ်။ `course_name` က `course_id`ကိုသွားချိတ် (depend) ဖြစ်နေပါတယ်။ `course_id` ကလည်း candidate key ထဲက proper subset တစ်ခုဖြစ်ပါတယ်။ ဒီလိုမျိုး non-prime attribute က proper subset of candidate key ကိုသွားပြီးမှီခိုနေတယ် (depend) ဖြစ်နေတယ်ဆို partial dependency ဖြစ်နေတယ်လို့ဆိုနိုင်ပါတယ်။ 72 | 73 | ဒါကို 2NF ပြောင်းဖို့အတွက်အောက်ကလို table တွေခွဲထားနိုင်ပါတယ်။ 74 | 75 | `course` table 76 | 77 | | course_id | course_name | 78 | |-----------|--------------------| 79 | | 101 | Database Fundamentals | 80 | | 102 | Advanced SQL Queries | 81 | | 103 | Data Modeling and Design | 82 | 83 | `student_course` table 84 | 85 | | student_id | course_id | 86 | |------------|-----------| 87 | | 1 | 101 | 88 | | 2 | 102 | 89 | | 3 | 103 | 90 | 91 | ဒီလိုခွဲထုတ်လိုက်ခြင်းဖြင့် non-prime attribute ဟာသူနဲ့သက်ဆိုင်တဲ့ `primary` key ပေါ်မှာပဲ depend လုပ်သွားမှာဖြစ်ပါတယ်။ 92 | 93 | Stuents column attribute တွေရှိနေသေးရင်`students` table သက်သက်ထပ်ထုတ်ထားနိုင်ပါတယ်။ 94 | 95 | --- 96 | ### Third Normal Form (3NF) 97 | 98 | 3NF ပြောင်းဖို့အတွက်ဆို table က 2NF ဖြစ်ထားရမယ်။ 99 | Transitive dependencies တွေမရှိရဘူး။ 100 | - Non-prime attribute တစ်ခုကနောက် non-prime attribute တစ်ခုကိုမှီခိုနေမယ်။ 101 | - တစ်နည်းအားဖြင့် A က B ကို depend ဖြစ်မယ်၊ B က primary key ကို depend ဖြစ်မယ်ဆိုရင် A က primary key အပေါ် transitively depend ဖြစ်သွားတယ်လို့ဆိုနိုင်ပါတယ်။ 102 | 103 | နားလည်လွယ်ဖို့အောက်ကဥပမာကိုကြည့်ရအောင်။ 104 | 105 | | employee_id | department_id | department_name | manager_name | 106 | |-------------|----------------|------------------|------------------| 107 | | 1 | 101 | IT | Alice Johnson | 108 | | 2 | 102 | HR | Bob Smith | 109 | | 3 | 101 | IT | Alice Johnson | 110 | 111 | `manager_name` ဆိုတဲ့ column က `department_id` ကို depend ဖြစ်နေတယ်၊ `department_id` က primary key ဖြစ်တဲ့ `employee_id` ကို depend ဖြစ်နေတဲ့အတွက် transitive dependency ဖြစ်နေတယ်လို့သတ်မှတ်နိုင်ပါတယ်။ 112 | 113 | 3NF ပြောင်းဖို့အတွက် `managers` နဲ့ `departments` table တွေကိုသက်သက်စီခွဲချနိုင်ပါတယ်။ 114 | 115 | `departments` Table 116 | 117 | | department_id | department_name | 118 | |---------------|------------------| 119 | | 101 | IT | 120 | | 102 | HR | 121 | 122 | `managers` Table 123 | 124 | | department_id | manager_name | 125 | |---------------|------------------| 126 | | 101 | Alice Johnson | 127 | | 102 | Bob Smith | 128 | 129 | `employees` Table ကတော့ joint table ဖြစ်သွားပါမယ်။ 130 | 131 | | employee_id | department_id | 132 | |-------------|----------------| 133 | | 1 | 101 | 134 | | 2 | 102 | 135 | | 3 | 101 | 136 | 137 | ဒါဆိုရင် `manager_name` သည် primary key အပေါ်မှာ transitively မဟုတ်ဘဲ directly depend ဖြစ်သွားပါပြီ။ 138 | 139 | BCNF ကိုမဆက်ခင် superkey အကြောင်းအရင်ရှင်းပေးချင်ပါသေးတယ်။ 140 | 141 | Superkey 142 | 143 | Superkey ဆိုတာကတော့ table ထဲမှာ row တိုင်းကို unique ဖြစ်နေနိုင်တဲ့ attribute တစ်ခုသို့ တစ်ခုထက်ပိုတဲ့ attribute set လိုက်လည်းဖြစ်နိုင်ပါတယ်။ တစ်နည်းအားဖြင့် superkey ဟာ candidate key တစ်ခု သို့ set of candidate keys လည်းဖြစ်နိုင်သလို တစ်ခြားသော attribute တွေလည်းဖြစ်နိုင်ပါတယ်။ 144 | 145 | ဥပမာ attribute A, B, C ရှိမယ်၊ {A, B} ဟာ`uniqueness` ကိုထိန်းထားနိုင်မယ်ဆို superkey ဖြစ်နိုင်မယ်။ သို့ပေမယ့် unique ဖြစ်နိုင်တယ်ဆို `superkey` အဖြစ် `C` ကိုလည်းထည့်နိုင်သလို {B, C} ပဲလည်းဖြစ်နိုင်တယ်။ Table ရဲ့ primary key ကို {A, B} လို့သတ်မှတ်ထားတယ်ဆို {A, B} က candidate key အဖြစ်ရှိမယ်၊ superkey လည်းဖြစ်မယ်။ candidate key ကိုယ်တိုင်ကိုက minimal super key အဖြစ်နဲ့တည်ရှိနေတာဖြစ်ပါတယ်။ ဆိုတော့ recap ပြန်လုပ်ရမယ်ဆို 146 | - primary key တိုင်းက candidate key 147 | - candidate key တိုင်းက superkey 148 | - သို့ပေမယ့် superkey တိုင်းကတော့ candidate, primary key မဖြစ်နိုင်ပါဘူး။ 149 | 150 | 151 | ![normalization](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/nor/nor1.png) 152 | 153 | Image credit: geekforgeek 154 | 155 | --- 156 | ### Boyce-Codd Normal Form (BCNF) 157 | BCNF form ရောက်ဖို့အတွက်ဆို 158 | - 3rd normal form ကိုရောက်ပြီးသားဖြစ်ရမယ်။ 159 | - Dependency တိုင်းမှာ determinant က super key ဖြစ်ရမယ်။ 160 | - E.g. A->B dependency မှာ left side က determinant သည် super key ဖြစ်ရမယ်။ 161 | အောက်က table တွေနဲ့ဥပမာထပ်ကြည့်ရအောင်။ 162 | 163 | | Employee_ID | project_name| Skill | 164 | |-------------|------------|------------| 165 | | 101 | projectA | Java | 166 | | 101 | projectB | SQL | 167 | | 102 | projectC | Python | 168 | | 103 | projectA | Go | 169 | 170 | employee တစ်ယောက်ဟာ project တစ်ခုထက်ပိုပြီးရှိနိုင်တယ်။ အပေါ်က table မှာ employee_id နဲ့ project_id ကိုပေါင်းလိုက်ရင် unique ဖြစ်ပြီးတော့ primary key ဖြစ်သွားပါတယ်၊ skill ကိုလည်းလှမ်းပြီးတော့ဆွဲထုတ်နိုင်ပါတယ်။ dependency ကနှစ်ခုထွက်သွားပါမယ်။ 171 | - Employee_id + project_id -> skill က dependency တစ်ခုရှိလာမယ်။ 172 | Skill တစ်ခုကို project တစ်ခုစီမှာပဲသုံးနေတယ်၊ Project တစ်ခုမှာတော့ skill တစ်ခုထပ်ပိုပြီးရှိနိုင်တဲ့အတွက် 173 | - Skill -> project_id dependency တစ်ခုရှိပါမယ်။ 174 | Skill သည် non-prime attribute ဖြစ်ပါတယ်၊ superkey ဖြစ်မနေပါဘူး။ ဒီအတွက်ကြောင့်အပေါ်က table သည် BCNF form ဖြစ်တယ်လို့ဆိုလို့မရပါဘူး။ 175 | 176 | အောက်ကအတိုင်းခွဲချလိုက်မယ်ဆိုရင်တော့ BCNF ကိုပြေလည်သွားစေမှာဖြစ်ပါတယ်။ 177 | 178 | `employee` table 179 | 180 | | Employee_ID | skill_id | 181 | |-------------|------------| 182 | | 101 | 1 | 183 | | 101 | 2 | 184 | | 102 | 3 | 185 | | 103 | 4 | 186 | 187 | `skills` table 188 | 189 | | skill_id | skill_name | project_name | 190 | |------------|------------|------------| 191 | | 1 | Java | ProjectA | 192 | | 2 | SQL | ProjectB | 193 | | 3 | Python | ProjectC | 194 | | 4 | Go | ProjectA | 195 | 196 | --- 197 | ### Fourth Normal Form (4NF) 198 | 4NF ကိုပြေလည်စေဖို့အတွက်ဆို table က 199 | - BCNF ဖြစ်ထားရမယ်။ 200 | - multi-value dependencies တွေရှိနေလို့မဖြစ်ပါဘူး။ 201 | Multi-value dependencies ဖြစ်နိုင်တဲ့အချက်တွေက 202 | - A->B dependency မှာ single A အတွက် B values တွေတစ်ခုထက်မကရှိနေမယ် 203 | - Table ကအနည်းဆုံး column 3 ခုရှိရမယ် 204 | - နှစ်ခုထဲဆို multi-row ခွဲချလိုက်ရုံနဲ့ multi-values မဖြစ်နိုင်တော့ပါဘူး။ 205 | - A->B က multi-values dependency ဖြစ်နေတယ်ဆို B->C ကတစ်ခုနဲ့တစ်ခု depend ဖြစ်နေလို့မရပါဘူး။ 206 | 207 | အောက်က table ကိုနမူနာကြည့်ရအောင် 208 | 209 | | customer_id | product | interest | 210 | |-------------|----------|----------| 211 | | 1 | Laptop | Gaming | 212 | | 1 | Smartphone | Programming | 213 | | 2 | laptop | Photography | 214 | | 2 | Smartphone | Gaming | 215 | 216 | `customer_id` 1 က product နှစ်ခု၊ interest နှစ်ခုမှာ record တွေရှိနိုင်ပါတယ်။ သေချာစဉ်းစားကြည့်လိုက်မယ်ဆို table structure ကမသေသပ်တာကိုတွေ့ရမယ်၊ product နဲ့ interest က independent ဖြစ်နေတဲ့အတွက် row နှစ်ကြောင်းထပ်ထွက်လာစေနိုင်ပါတယ်။ ဒီလိုမျိုးပေါ့ 217 | 218 | | customer_id | product | interest | 219 | |-------------|----------|----------| 220 | | 1 | Laptop | Gaming | 221 | | 1 | Smartphone | Programming | 222 | | 1 | Laptop | Programming | 223 | | 1 | Smartphone | Gaming | 224 | 225 | Multi-value dependency ကြောင့်မလိုအပ်ဘဲ row တွေကို repeat ဖြစ်စေပါတယ်။ 226 | 227 | အောက်ကလိုမျိုးခွဲချပြီးတော့ပြေလည်အောင်လုပ်ပေးနိုင်ပါတယ်။ 228 | 229 | `orders` table 230 | | order_id | customer_id | product | 231 | |-------------|-------------|------------| 232 | | 1 | 1 | Laptop | 233 | | 2 | 2 | Smartphone | 234 | 235 | `interest` table 236 | | interest_id | customer_id | interest | 237 | |-------------|-------------|--------------| 238 | | 1 | 1 | Gaming | 239 | | 2 | 1 | Programming | 240 | | 3 | 2 | Photography | 241 | | 4 | 2 | Gaming | 242 | 243 | `customers` table ကသက်သက်နောက် table တစ်လုံးအနေနဲ့ရှိနေပါမယ်။ 244 | 245 | 246 | --- 247 | 248 | ### Fifth Normal Form (5NF): Join Dependencies 249 | 250 | 5NF ပြေလည်ဖို့အတွက်ဆို table တွေဟာ 251 | - 4th normal form ပြေလည်ပြီးသားဖြစ်ရမယ်။ 252 | - Join dependency မရှိရဘူး။ 253 | - Joining ကြောင့် data ဆုံးရှုံးမှုမရှိစေရဘူး။ 254 | - DB ထဲမှာရှိတဲ့ tables တွေဟာတတ်နိုင်သလောက်မတူညီတဲ့ keys တွေနဲ့ tables အသေးတွေပြန်ခွဲထားနိုင်ရမယ် 255 | - တူညီတဲ့ key နဲ့ခွဲမယ်ဆိုဆုံးတော့မှာမဟုတ်ပါ။ 256 | - Table ပြန်ခွဲတဲ့နေရာမှာလည်း business logic ပေါ်မူတည်ပါသေးတယ်။ 257 | 258 | 5th normal form ကို Project join normal form လို့လည်းခေါ်ပါတယ်။ 259 | 260 | ပိုနားလည်လွယ်အောင်အောက်ကဥပမာတွေကိုဆက်ကြည့်ရအောင်။ 261 | 262 | | ProjectID | EmployeeID | ProjectName | EmployeeName | HoursWorked | 263 | |-----------|------------|-------------|----------------|-------------| 264 | | 101 | 1 | Project A | John Doe | 20 | 265 | | 101 | 2 | Project A | Jane Smith | 15 | 266 | | 102 | 1 | Project B | John Doe | 25 | 267 | | 102 | 3 | Project B | Bob Johnson | 30 | 268 | 269 | ဒီ table မှာ project_id + employee_id က primary key ဖြစ်မယ်။ သို့ပေမယ့်ဒီ primary key မှာ project_name data တွေထပ်နေတဲ့အတွက် data redundancy(data ဆုံးရှုံးမှု) ရှိနေပါတယ်။ 270 | 271 | Table ကို 5th normal form ပြောင်းမယ်ဆိုဒီလိုဖြစ်သွားပါမယ်။ 272 | 273 | `project` table 274 | | ProjectID | ProjectName | 275 | |-----------|-------------| 276 | | 101 | Project A | 277 | | 102 | Project B | 278 | 279 | `employee` table 280 | 281 | | EmployeeID | EmployeeName | 282 | |------------|----------------| 283 | | 1 | John Doe | 284 | | 2 | Jane Smith | 285 | | 3 | Bob Johnson | 286 | 287 | `work_hour` table 288 | 289 | | ID | ProjectID | EmployeeID | HoursWorked | 290 | |-----------|-----------|------------|-------------| 291 | |1| 101 | 1 | 20 | 292 | |2| 101 | 2 | 15 | 293 | |3| 102 | 1 | 25 | 294 | |4| 102 | 3 | 30 | 295 | 296 | မတူညီတဲ့ keys တွေနဲ့ table အသေးလေးတွေပြန်ခွဲချလိုက်မယ်။ Join လုပ်ကြည့်မယ်ဆိုလည်း data ဆုံးရှုံးမှုမရှိနိုင်တော့တာကိုတွေ့ရပါမယ်။ 297 | 298 | Normalization ကိုနားလည်သွားမယ်ဆို database တွေကို optimize လုပ်နိုင်လာမယ့်အပြင် data redundancy ဖြစ်နိုင်မှုကိုကျော်ဖြတ်နိုင်မယ်၊ data integrity ပိုကောင်းလာပါလိမ့်မယ်။ ဒါ့အပြင် data dependencies အကြောင်းတွေ ၊ multi-values အကြောင်းတွေကိုပါနားလည်သွားမယ့်အတွက် structure ကျတဲ့ databases တွေကိုတည်ဆောက်နိုင်သွားမှာဖြစ်ပါတယ်။ 299 | 300 | 301 | နိဂုံးချုပ်ရမယ်ဆိုတစ်ကယ်လက်တွေ့ project တွေမလုပ်သေးဘူးတဲ့သူတွေအတွက် normalization ကိုကွက်ကွက်ကွင်းကွင်းနားလည်ဖို့ဆိုတာခက်ပါတယ်။ ဒီ article series လေးကနေအတိုင်းအတာတစ်ခုအ ထိသဘောတရားကိုနားလည်သွားပြီး လက်တွေ့လုပ်တဲ့အခါမှာ memory တစ်ခုအနေနဲ့ပြန်ပြီးအသုံးချနိုင်သွားတယ်၊ ဆက်စပ်နိုင်သွားဖို့မျှော်လင့်ပါတယ်။ 302 | -------------------------------------------------------------------------------- /operators.md: -------------------------------------------------------------------------------- 1 | ## Logical & Comparison Operators 2 | ဒီ article မှာတော့ Operators တွေအကြောင်းကိုရေးသွားမှာဖြစ်ပါတယ်။ Logical and Comparison operators တွေကိုများသောအားဖြင့် data ဆွဲထုတ်တဲ့ queries တွေမှာအသုံးပြုကြပါတယ်။ Operators ဆိုလို့ထူးထူးဆန်းဆန်းတော့မဟုတ်ဘူး၊ အများစုကို အရှေ့ကအပိုင်းတွေမှာတွေ့ပြီးသားဖြစ်ပါတယ်၊ section တစ်ခုအနေနဲ့သီးသန့်ဖော်ပြချင်တဲ့အတွက်သာရေးလိုက်ခြင်းဖြစ်ပါတယ်။ Easy going ဖြစ်တဲ့အတွက် သိပြီးသား query တွေအတွက်ကျနော် screenshots တွေမထည့်ပေးထားပါဘူး။ 3 | 4 | ### Logical Operators 5 | #### AND 6 | `AND` keyword ကိုတော့တစ်ခုထက်ပိုတဲ့ conditions တွေကိုချိတ်ဆက်ပြီး data ဆွဲချင်တဲ့အချိန်မှာအသုံးပြုပါတယ်။ သုံးနေကျ `students` table က အသက် `20` ဖြစ်ပြီး `Computer Science` major ယူထားတဲ့ကျောင်းသားကိုထုတ်ကြည့်ရအောင်။ 7 | 8 | ``` 9 | SELECT * FROM students 10 | WHERE major = 'Computer Science' 11 | AND age = 20; 12 | ``` 13 | #### OR 14 | `OR` ကတော့တစ်ခုထက်ပိုတဲ့ conditions တွေထဲကမှ တစ်ခုခုက valid ဖြစ်တယ်ဆိုရင် data ဆွဲထုတ်ချင်တဲ့နေရာမှာသုံးပါတယ်။ `students` table ထဲကနေ `major` က `Physics` `သို့မဟုတ် (OR)` `Mathematics` ဖြစ်တဲ့ကျောင်းသားတွေကိုဆွဲထုတ်ကြည့်ရအောင်။ 15 | 16 | ``` 17 | SELECT * FROM students 18 | WHERE major = 'Mathematics' 19 | OR major = 'Physics'; 20 | ``` 21 | 22 | #### NOT 23 | 24 | `NOT` ကိုတော့ ဒီ `condition` ကလွဲလို့ကျန်တဲ့ data ကအကုန်ပြပေးပါဆိုတဲ့အခြေအနေတွေမှာအသုံးပြုပါတယ်။ သိပ်မသုံးလောက်ဘူးထင်ရပေမယ့် အသုံးဝင်တဲ့ထဲမှာပါပါတယ်။ `students`table ထဲမှာ `Chemistry` major ကကျောင်းသားလွှဲလို့ကျန်တဲ့ကျောင်းသား data အကုန်ဆွဲထုတ်ချင်တယ်ဆိုပါစို့။ 25 | ``` 26 | SELECT * FROM students 27 | WHERE NOT major = 'Chemistry'; 28 | ``` 29 | 30 | #### LIKE 31 | 32 | `%` sign ကိုအသုံးပြုပြီး pattern ကိုက်ညီတဲ့ data တွေကိုဆွဲထုတ်လိုတဲ့အချိန်မှာအသုံးပြုပါတယ်၊ Search လုပ်တယ်လို့လဲခေါ်နိုင်ပါတယ်။ % sign နဲ့ပတ်သတ်တဲ့ pattern အသေးစိတ်ကိုအရှေ့ပိုင်းတွေမှာပြောခဲ့ပါတယ်၊ မေ့နေရင်ပြန်ရှာဖတ်နိုင်ပါတယ်။ 33 | 34 | `students` table ထဲက `name` ဆိုတဲ့ column မှာ `John` ဆိုတဲ့စာသားပါတဲ့ data တွေကိုဆွဲထုတ်ချင်တယ်ဆိုပါစို့။ 35 | ``` 36 | SELECT * FROM students 37 | WHERE name LIKE '%John%'; 38 | ``` 39 | ![OP1](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/op/op1.png) 40 | 41 | --- 42 | 43 | #### NOT LIKE 44 | 45 | `LIKE` keyword ရဲ့ပြောင်းပြန်ပဲပေါ့။ LIKE ကကိုက်ညီတဲ့စာသားကိုပြတယ်၊ `NOT LIKE` ဆိုရင်တော့အဲ့ဒီ pattern (စာသား) မပါတဲ့ data တွေကိုပြမယ်။ 46 | 47 | `students` table ထဲမှာ `name` column က `Alice` ဆိုတဲ့စာသားမပါတဲ့ data တွေကိုလိုချင်တယ်ဆိုအောက်ကအတိုင်း `NOT LIKE` ကိုသုံးပြီးရေးနိုင်ပါတယ်။ 48 | ``` 49 | SELECT * FROM students 50 | WHERE name NOT LIKE '%Alice%'; 51 | ``` 52 | 53 | ![OP2](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/op/op2.png) 54 | 55 | --- 56 | 57 | ### Comparison Operators 58 | 59 | #### Equal (=) 60 | 61 | နှိုင်းယှဉ်ကြည့်ပြီး တူညီတဲ့တန်ဖိုးရှိတဲ့ data တွေကိုဆွဲထုတ်နိုင်ပါတယ်။ 62 | `students` table ထဲမှာ `age` ဆိုတဲ့ column က `21` ဖြစ်တဲ့ data တွေကိုလိုချင်တယ်ဆိုပါစို့။ 63 | ``` 64 | SELECT * FROM students 65 | WHERE age = 21; 66 | ``` 67 | 68 | #### Not Equal (<>) 69 | `Equal =` နဲ့ပြောင်းပြန်ဖြစ်သွားပါမယ်။ နှိုင်းယှဉ်ကြည့်ပြီးမတူညီတဲ့ data ပေါ့။ 70 | `students` table ထဲမှာ `major` column က `Physics` မဟုတ်တဲ့ data တွေကိုလိုချင်တယ်ဆိုအောက်ကအတိုင်းရေးနိုင်ပါတယ်။ 71 | ``` 72 | SELECT * FROM students 73 | WHERE major <> 'Physics'; 74 | ``` 75 | 76 | #### Greater Than (>), Less Than (<) 77 | 78 | နှိုင်းယှဉ်ကြည့်ပြီး ကြီးသလား၊ ငယ်သလားဆိုတဲ့ condition ပေါ်မူတည်ပြီး data တွေဆွဲထုတ်နိုင်ပါတယ်။ 79 | `students` table ထဲမှာ `age` column ကို `22` ထက်ငယ်တဲ့ data တွေကိုလိုချင်တယ်။ 80 | 81 | ``` 82 | SELECT * FROM students 83 | WHERE age < 22; 84 | ``` 85 | 86 | `22`ထက်ကြီးတဲ့ data လိုချင်တယ်ဆိုရင်တော့ greater than `>` sign ကိုသုံးနိုင်ပါတယ်။ 87 | 88 | #### Greater Than or Equal To (>=), Less Than or Equal To (<=) 89 | ကြီးပြီးတော့တူတယ်၊ ငယ်ပြီးတော့တူတယ် ဆိုတဲ့ conditions တွေရှိတဲ့အချိန်မှာ `>=, <=` signs တွေကိုသုံးပါတယ်။ 90 | 91 | `students` table ထဲမှာ `age` column တန်ဖိုးက `20` ထက်ကြီးရမယ်၊ တူလည်းရတယ် ဆိုတဲ့အခြေအနေမှာအောက်က query လိုမျိုးအသုံးပြုနိုင်ပါတယ်။ 92 | ``` 93 | SELECT * FROM students 94 | WHERE age >= 20; 95 | ``` 96 | ![OP3](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/op/op3.png) 97 | 98 | --- 99 | အထက်မှာဖော်ပြခဲ့တဲ့ Logical & comparison operators တွေဟာအခြေခံကျပြီး နေ့တဓူဝအသုံးပြုမယ့် queries တွေထဲပါဝင်ပါတယ်။ ရေးရတာလွယ်ကူပေမယ့် အသုံးဝင်တဲ့အရာတွေမို့လို့ သေချာလေးမိမိဘာသာထပ်ပြီးတော့လေ့ကျင့်ထားစေချင်ပါတယ်။ 100 | 101 | -------------------------------------------------------------------------------- /relationship.md: -------------------------------------------------------------------------------- 1 | ## Relationships in SQL 2 | 3 | ဒီအပိုင်းမှာတော့ execute လုပ်တဲ့ screenshots တွေမပါသေးပါဘူး။ SQL ရဲ့ `relationship` အကြောင်းကိုပေါ်လွင်အောင်ရှင်းပြပေးပြီးတော့ နောက်အပိုင်းတွေမှာတစ်ခုခြင်းဆီကို နမူနာတွေနဲ့တကွ run ကြည့်သွားပါမယ်။ 4 | 5 | SQL မှာ `relationship` ဆိုတာက Tables တွေကိုချိတ်ဆက်ပြီးလိုအပ်သလို data တွေကိုဆွဲထုတ်ခြင်းကိုဆိုလိုပါတယ်။ Table တစ်လုံးခြင်းဆီတိုင်းက သီးသန့်ရပ်တည်နိုင်သလို တစ်လုံးနှင့်တစ်လုံး `ပတ်သက်ဆက်နွယ်ခြင်း` မျိုးတွေလည်းရှိနိုင်ပါတယ်၊ ဒီလိုပတ်သက်ဆက်နွယ်ခြင်းကို `relationship` အနေနဲ့သတ်မှတ်နိုင်ပြီး Table တစ်လုံးနဲ့တစ်လုံးဘယ်လိုချိတ်ဆက်နိုင်မလဲဆိုတာကို အောက်မှာဥပမာတွေပေးပြီးရှင်းပြပေးသွားပါမယ်။ 6 | 7 | ### Primary Key 8 | 9 | Primary Key ဆိုတာကတော့ Table တစ်လုံးမှာရှိတဲ့ unique identifier column ဖြစ်ပါတယ်။ `unique` ဖြစ်တယ်ဆိုတာ record (row) တိုင်းမှာပါတဲ့ အဲ့ဒီ column ရဲ့ value မှာ `ထပ်` နေခြင်းမရှိတာကိုဆိုလိုခြင်းဖြစ်ပါတယ်။ 10 | 11 | ဥပမာအောက်က `employees`ဆိုတဲ့ Table မှာ `employee_id` ဆိုတဲ့ column ဟာအမြဲတမ်း `unique` ဖြစ်နေနိုင်တဲ့အတွက် `PRIMARY KEY` အဖြစ်သတ်မှတ်ထားလို့ရပါတယ်။ 12 | 13 | ``` 14 | CREATE Table employees ( 15 | employee_id INT PRIMARY KEY, 16 | name VARCHAR(50), 17 | department_id INT 18 | ); 19 | ``` 20 | 21 | ဒီ `PRIMARY KEY` ကို Table တွေ `relationship` ချိတ်ဆက်တဲ့နေရာမှာလည်းပြန်လည်အသုံးပြုပါတယ်။ 22 | 23 | ### Foreign Keys 24 | 25 | Foreign Key ဆိုတာကတော့တစ်ခြား Table တစ်လုံးက primary key ဖြစ်ပါတယ်။ Table နှစ်လုံးကိုချိတ်ဆက်တဲ့အခါအသုံးပြုတဲ့အရာပဲဖြစ်ပါတယ်။ Table B က Table A ကိုချိတ်ဆက်ချင်တယ်ဆို Table B ထဲမှာ Table A ရဲ့ primary key ကိုထည့်လိုက်ခြင်းဖြင့်ချိတ်ဆက်နိုင်ပါတယ်။ 26 | အောက်ကဥပမာကိုကြည့်လိုက်ရင်ပိုပြီးမြင်သွားလိုက်ပါမယ်။ 27 | ``` 28 | CREATE Table departments ( 29 | department_id INT PRIMARY KEY, 30 | department_name VARCHAR(50) 31 | ); 32 | ``` 33 | 34 | `departments` ဆိုတဲ့ Table တစ်လုံးရှိပါမယ်၊ `department_id` ကို `PRIMARY KEY` အဖြစ်သတ်မှတ်ထားပါတယ်။ 35 | 36 | ``` 37 | CREATE Table employees ( 38 | employee_id INT PRIMARY KEY, 39 | name VARCHAR(50), 40 | department_id INT, 41 | FOREIGN KEY (department_id) REFERENCES departments(department_id) 42 | ); 43 | ``` 44 | 45 | `employees` ဆိုတဲ့ Table ထဲမှာ `department_id` ထည့်ထားပြီး `FOREIGN KEY` အဖြစ်သတ်မှတ်လိုက်မယ်ဆို `employees` Table ကနေတစ်ဆင့် `departments` Table ထဲက data တွေကိုပါဆွဲထုတ်နိုင်သွားမှာဖြစ်ပါတယ်။ `department_id` က `departments` Table ထဲမှာတော့ `PRIMARY KEY` ဖြစ်ပေမယ့် `employees` Table ထဲမှာတော့ `FOREIGN KEY` အနေနဲ့ဖြစ်သွားပါတယ်။ 46 | 47 | ``` 48 | FOREIGN KEY (department_id) REFERENCES departments(department_id) 49 | ``` 50 | 51 | ဒါကတော့ `FOREIGN KEY` အဖြစ်သတ်မှတ်ကြောင်းရေးတဲ့အပိုင်းဖြစ်ပါတယ်။ ဘယ် Table ကို `REFERENCES (link)` လုပ်မလဲဆိုတာကိုပါထည့်သွင်းပေးရပါမယ်။ 52 | 53 | ### Types of Relationships 54 | Relationship ရဲ့သဘောတရားကိုနားလည်သွားပြီဆိုတော့ relationship `type` အကြောင်းလေးတွေကိုဆက်ရှင်းပေးသွားပါမယ်။ Table တစ်လုံးနဲ့တစ်လုံးချိတ်ဆက်တဲ့အချိန်မှာ ချိတ်ဆက်နိုင်တဲ့ `အမျိုးအစား` တွေလို့လည်းဆိုနိုင်ပါတယ်။ 55 | 56 | #### One To One Relationship 57 | Table တစ်ခုနဲ့တစ်ခုဟာ `one to one` ပုံစံမျိုးနဲ့ပဲချိတ်ဆက်ထားတာကို one to one relationship လို့ခေါ်ပါတယ်။ ဥပမာအောက်ကနမူနာမှာဆို `students` Table နဲ့ `student_details` ဆိုတဲ့ Table နှစ်လုံးရှိပါတယ်။ `student` တစ်ယောက်ဟာ သူနဲ့ပတ်သတ်တဲ့ `detail` record တစ်ခုပဲရှိနိုင်ပါတယ်။ ဒါကြောင့်မို့ ဒီ Table နှစ်လုံးရဲ့ relationship ပုံစံဟာ `one to one` ဖြစ်ပါတယ်။ 58 | 59 | ``` 60 | CREATE Table students ( 61 | student_id INT PRIMARY KEY, 62 | name VARCHAR(50) 63 | ); 64 | ``` 65 | 66 | ``` 67 | CREATE Table student_details ( 68 | student_id INT PRIMARY KEY, 69 | address VARCHAR(100), 70 | FOREIGN KEY (student_id) REFERENCES students(student_id) 71 | ); 72 | ``` 73 | #### One To Many Relationship 74 | 75 | Tableတစ်လုံးက record သည် နောက် Table တစ်လုံးမှာ တစ်ခုထက်ပိုသော records တွေအဖြစ်ချိတ်ဆက်နိုင်ခြေရှိတယ်ဆို `one to many` relationship ပုံစံမျိုးဖြစ်နိုင်ပါတယ်။ 76 | 77 | ဥပမာအောက်ကနမူနာမှာဆို `author` Table တစ်လုံးရှိပါမယ်။ `author` တစ်ယောက်ကစာအုပ်တွေတစ်အုပ်ထက်ပိုပြီးရေးနိုင်ပါတယ်။ ဒါကြောင့် `books` Table မှာ `author_id` ကို foreign key အဖြစ်ထားပြီး `one to many` relationship ပုံစံမျိုးချိတ်ဆက်နိုင်ပါတယ်။ 78 | `authors` -> one , `books` -> many ဖြစ်သွားပါမယ်။ 79 | 80 | ဒီလိုချိတ်ဆက်လိုက်ခြင်းအားဖြင့် `books` Table ထဲက records တွေကိုဆွဲထုတ်တဲ့အချိန်မှာ အဲ့ဒီ book record ရဲ့ `author` information တွေကိုတစ်ပါတည်းဆွဲနိုင်မှာဖြစ်ပါတယ်။ 81 | 82 | ``` 83 | CREATE Table authors ( 84 | author_id INT PRIMARY KEY, 85 | name VARCHAR(50) 86 | ); 87 | ``` 88 | ``` 89 | CREATE Table books ( 90 | book_id INT PRIMARY KEY, 91 | title VARCHAR(100), 92 | author_id INT, 93 | FOREIGN KEY (author_id) REFERENCES authors(author_id) 94 | ); 95 | ``` 96 | 97 | #### Many To Many Relationship 98 | Table နှစ်လုံးလုံးဟာအခြင်းခြင်း တစ်ခုထက်ပိုတဲ့ records တွေအပြန်အလှန်ရှိနိုင်ခြေရှိတယ်ဆို `many to many` relationship ပုံစံမျိုးဖြစ်သွားနိုင်ပါတယ်။ ဒီလိုအခြေအနေမှာတော့ကြည့်ရတာပိုပြီးရှင်းလင်းအောင် ကြားခံ Table တစ်လုံးဆောက်လေ့ရှိကြပါတယ်။ Table နှစ်လုံးကို ကြားခံဆက်သွယ်ပေးတဲ့ပုံစံဖြစ်ပါတယ်။ `junction` Table, `associative` Table လို့လည်းခေါ်ကြပါတယ်။ 99 | 100 | အောက်ကနမူနာကိုကြည့်မယ်ဆို `students` Table နဲ့ `courses` Table ကိုမြင်ရပါမယ်။ student တစ်ယောက်ဟာ course တွေအများကြီးရှိနိုင်သလို course တစ်ခုမှာလည်း student တွေအများကြီးတက်ရောက်နေတာမျိုးရှိပါတယ်။ ဒီလိုအခြေအနေကို `many to many` လို့ခေါ်ဆိုနိုင်ပြီး ဒီနှစ်ခုကိုလွယ်ကူစွာချိတ်ဆက်နိုင်ရန်အတွက် `student_courses` ဆိုပြီးကြားခံ `junction` Table တစ်ခုဆောက်နိုင်ပါတယ်။ Junction Table ထဲမှာ `students` Table နဲ့ `courses` Table ကို reference လုပ်နိုင်တဲ့ `FOREIGN KEYS` တွေထည့်လိုက်ရုံပါပဲ။ 101 | ``` 102 | CREATE Table students ( 103 | student_id INT PRIMARY KEY, 104 | name VARCHAR(50) 105 | ); 106 | ``` 107 | 108 | ``` 109 | CREATE Table courses ( 110 | course_id INT PRIMARY KEY, 111 | course_name VARCHAR(100) 112 | ); 113 | ``` 114 | ``` 115 | CREATE Table student_courses ( 116 | student_course_id INT PRIMARY KEY, 117 | student_id INT, 118 | course_id INT, 119 | FOREIGN KEY (student_id) REFERENCES students(student_id), 120 | FOREIGN KEY (course_id) REFERENCES courses(course_id) 121 | ); 122 | ``` 123 | 124 | ဒီအပိုင်းမှာ relationship ဆိုတာကို theoretically အရ နားလည်ရလွယ်ကူအောင်အရင်ရှင်းပြပေးခဲ့ပါတယ်။ relationship ဆိုတာဘာလဲ၊ ဘယ်လိုမျိုးချိတ်ဆက်နိုင်တယ်၊ ဘယ်လို relationship အမျိုးအစားတွေရှိမယ်ဆိုတာတွေကိုရေးခဲ့ပါတယ်။ လက်တွေ့ query တွေကို execute မလုပ်ရသေးတဲ့အတွက်နည်းနည်းနားလည်ရခက်နိုင်ပေမယ့် နောက်အပိုင်းတွေမှာ relationship အမျိုးအစားတွေကို တစ်ခုခြင်းဆီအသေးစိတ်ပြန်ရေးရင်း query တွေ run ကြည့်သွားမှာဖြစ့်တဲ့အတွက် ပိုပြီးနားလည်သွားမယ်လို့ထင်ပါတယ်။ 125 | -------------------------------------------------------------------------------- /rtq.md: -------------------------------------------------------------------------------- 1 | ## Relationships In Queries 2 | 3 | အရှေ့အပိုင်းမှာရေးခဲ့တဲ့ one to one, one to many, many to many relationship တွေအကြောင်းကိုအခုအပိုင်းမှာလက်တွေ့ query တွေရေးကြည့်ပြီးထပ်လေ့လာသွားကြပါမယ်။ INNER နဲ့ LEFT JOIN တွေကိုအဓိကထားပြီးသုံးသွားမှာဖြစ်လို့ဘယ်လိုပုံစံမျိုးလိုချင်တဲ့အခါ ဘယ် JOIN ကိုသုံးနိုင်တယ်ဆိုတာမျိုးကိုပါတစ်ပါတည်းမှတ်သွားစေချင်ပါတယ်။ 4 | 5 | ### One to one 6 | Query တွေစမ်းပြီးရေးကြည့်ဖို့အတွက် `students` နဲ့ `student_details`table နှစ်လုံးကိုအသုံးပြုပါမယ်။ `student` တစ်ယောက်မှာ detail info တစ်ခုသာရှိနိုင်ပါတယ်။ (One to one relationship type) 7 | 8 | `students` table ထဲမှာရှိတဲ့ records တွေကိုသက်ဆိုင်ရာ `student_details` records တွေနဲ့အတူ JOIN လုပ်ပြီးဆွဲထုတ်ကြည့်ပါမယ် 9 | ``` 10 | SELECT students.student_id, students.name, student_details.address FROM students JOIN student_details ON students.student_id = student_details.student_id; 11 | ``` 12 | 13 | ![rtq](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/rtq/rtq1.png) 14 | 15 | --- 16 | 17 | `student_details` ဘက်မှာ records မရှိတဲ့ `students` တွေကိုထုတ်ကြည့်ပါမယ်။ 18 | ``` 19 | SELECT students.student_id, students.name FROM students LEFT JOIN student_details ON students.student_id = student_details.student_id WHERE student_details.student_id IS NULL; 20 | ``` 21 | ![rtq](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/rtq/rtq2.png) 22 | 23 | --- 24 | `students` တစ်ယောက်တည်းကိုပဲသူ့ရဲ့ details record နဲ့အတူဆွဲထုတ်ကြည့်ပါမယ်။ 25 | ``` 26 | SELECT students.name, student_details.address FROM students LEFT JOIN student_details ON students.student_id = student_details.student_id WHERE students.student_id = 2; 27 | ``` 28 | ![rtq](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/rtq/rtq3.png) 29 | 30 | --- 31 | 32 | ### One-to-Many Relationship: 33 | 34 | Relationship အပိုင်းမှာတုန်းက create လုပ်ခဲ့တဲ့ `authors` နဲ့ `books` table ကိုအသုံးပြုပါမယ်။ `authors` တစ်ယောက်မှာရေးခဲ့တဲ့ `books` တွေအများကြီးရှိနိုင်တယ်ဆိုတဲ့ **one to many** relationship ပုံစံဖြစ်ပါတယ်။ Table အလွတ်တွေဖြစ်တဲ့အတွက် data တွေအရင်ထည့်ပါမယ်။ 35 | ``` 36 | -- Insert authors 37 | INSERT INTO authors (author_id, name) VALUES 38 | (1, 'Jane Doe'), 39 | (2, 'John Smith'), 40 | (3, 'Alice Johnson'); 41 | ``` 42 | ``` 43 | -- Insert books 44 | INSERT INTO books (book_id, title, author_id) VALUES 45 | (101, 'The Art of SQL', 1), 46 | (102, 'Database Design Mastery', 1), 47 | (103, 'Query Optimization Techniques', 2), 48 | (104, 'Introduction to Relational Databases', 3); 49 | ``` 50 | ![rtq](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/rtq/rtq4.png) 51 | ![rtq](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/rtq/rtq5.png) 52 | 53 | --- 54 | စာအုပ်တွေကိုဆွဲထုတ်ရင်းတစ်ပါတည်းရေးခဲ့တဲ့ author တွေကိုပါထုတ်ကြည့်ပါမယ်။ 55 | ``` 56 | SELECT books.book_id, books.title, authors.name AS author_name FROM books JOIN authors ON books.author_id = authors.author_id; 57 | ``` 58 | 59 | ![rtq](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/rtq/rtq6.png) 60 | 61 | --- 62 | 63 | စာအုပ်မရေးဖူးတဲ့ author record ကိုဆွဲထုတ်ကြည့်ပါမယ်။ 64 | ``` 65 | SELECT authors.author_id, authors.name FROM authors LEFT JOIN books ON authors.author_id = books.author_id WHERE books.book_id IS NULL; 66 | ``` 67 | 68 | ![rtq](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/rtq/rtq7.png) 69 | 70 | --- 71 | 72 | လောလောဆယ်သွင်းထားတဲ့ data အရ စာအုပ်မရေးထားတဲ့ author record မရှိတဲ့အတွက်ကြောင့် author record အသစ်တစ်ကြောင်းထည့်ကြည့်ပြီး query ကိုပြန် run ကြည့်ပါမယ်။ 73 | 74 | ![rtq](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/rtq/rtq8.png) 75 | 76 | book record မရှိတဲ့ author တစ်ယောက်ဖန်တီးလိုက်ပါပြီ။ Query ကိုပြန် run ကြည့်မယ်ဆို book record reference မရှိတဲ့ author record ကိုမြင်ရမှာဖြစ်ပါတယ်။ 77 | 78 | 79 | 80 | ### Many-to-Many Relationship: 81 | 82 | `students` တစ်ယောက်မှာ `courses` တွေအများကြီးရှိနိုင်သလို `courses` တစ်ခုမှာလည်း `students` အများကြီးရှိနေနိုင်တဲ့ many to many relationship type ဖြစ်ပါတယ်။ 83 | Table အလွတ်တွေဖြစ်တဲ့အတွက်ထုံးစံအတိုင်း data တွေအရင်ထည့်ပါမယ်။ 84 | ``` 85 | -- Insert courses 86 | INSERT INTO courses (course_id, course_name) VALUES 87 | (201, 'Database Fundamentals'), 88 | (202, 'Advanced SQL Queries'), 89 | (203, 'Data Modeling and Design'), 90 | (204, 'Database Administration'); 91 | ``` 92 | ![rtq](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/rtq/rtq10.png) 93 | 94 | --- 95 | 96 | ``` 97 | -- Insert student courses 98 | INSERT INTO student_courses (student_course_id, student_id, course_id) VALUES 99 | (1, 1, 201), 100 | (2, 1, 202), 101 | (3, 2, 202), 102 | (4, 2, 203), 103 | (5, 3, 201), 104 | (6, 3, 204); 105 | ``` 106 | ![rtq](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/rtq/rtq11.png) 107 | 108 | --- 109 | 110 | `student_id` 1 ဖြစ်တဲ့ကျောင်းသားကဘယ်လို `courses` တွေယူထားလဲဆိုတာဆွဲကြည့်ရအောင်။ Many to many relation ဖြစ်တဲ့ဒီနေရာမှာ junction table တစ်ခုခံထားတဲ့အတွက် JOIN ကနှစ်ခါဖြစ်သွားတာကိုသတိချပ်ထားရပါမယ်။ 111 | 112 | ``` 113 | SELECT students.name, courses.course_name FROM students JOIN student_courses ON students.student_id = student_courses.student_id JOIN courses ON student_courses.course_id = courses.course_id WHERE students.student_id = 1; 114 | ``` 115 | 116 | ![rtq](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/rtq/rtq12.png) 117 | 118 | --- 119 | 120 | `course_id` 201 မှာတက်ရောက်နေတဲ့ `students` တွေကိုလည်းထုတ်ကြည့်နိုင်ပါတယ်။ 121 | ``` 122 | SELECT courses.course_name, students.name FROM courses JOIN student_courses ON courses.course_id = student_courses.course_id JOIN students ON student_courses.student_id = students.student_id WHERE courses.course_id = 201; 123 | ``` 124 | 125 | ![rtq](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/rtq/rtq13.png) 126 | 127 | --- 128 | 129 | `students` ရော `courses` တွေရောအားလုံးကိုဆွဲထုတ်ကြည့်ပါမယ်။ `courses` တွေတက်ရောက်ထားခြင်းမရှိတဲ့ကျောင်းသားတွေတော့ `COALESCE` ဆိုတဲ့ function ကိုသုံးပြီးတော့ `course_name` နေရာမှာ `No Course`ဆိုတဲ့စာသားတစ်ခုအစားထိုးထည့်ပေးလိုက်ပါမယ်။ 130 | 131 | ``` 132 | SELECT students.name, COALESCE(courses.course_name, 'No Course') AS course_name FROM students LEFT JOIN student_courses ON students.student_id = student_courses.student_id LEFT JOIN courses ON student_courses.course_id = courses.course_id; 133 | ``` 134 | 135 | ![rtq](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/rtq/rtq14.png) 136 | 137 | --- 138 | 139 | ဒီအပိုင်းထိရောက်လာပီဆိုရင် query တွေနည်းနည်းအဆင့်မြင့်လာတာနဲ့အတူသူတို့ရဲ့ complexity ရှုပ်ထွေးမှုအပိုင်းလေးတွေကိုပါအနည်းငယ်ခံစားလာရမှာဖြစ်ပါတယ်။ သို့ပေမယ့် အရှေ့နှစ်ပိုင်းမှာရေးခဲ့တဲ့ relationship types , joins တွေအကြောင်းကိုသေချာလိုက်လုပ်ထားမယ်ဆို ဒီအပိုင်းကိုလည်းလိုက်နိုင်မယ်လို့ထင်ပါတယ်။ စာသိပ်မလိုက်နိုင်ဘူးဆို relationship နဲ့ join အပိုင်းကို revision ပြန်လုပ်ပြီးပြန်ဖတ်ပါလို့တိုက်တွန်းချင်ပါတယ်။ 140 | 141 | 142 | 143 | -------------------------------------------------------------------------------- /sf.md: -------------------------------------------------------------------------------- 1 | ## Sorting & filtering 2 | 3 | ဒီအပိုင်းမှာတော့ db ထဲက data တွေကို sorting စီတာတွေနဲ့ လိုအပ်တဲ့ data ကိုပဲသီးသန့်ဆွဲထုတ်တဲ့ `filtering` queries တွေကိုလေ့လာသွားကြပါမယ်။ 4 | 5 | `sql_test` ဆိုတဲ့ database ထဲမှာ `students` table တစ်လုံးဆောက်ထားလိုက်ပြီး `INSERT` command နဲ့ data တစ်ချို့ထည့်သွင်းထားပါမယ်။ ဒီ students table ကိုအသုံးပြုပြီး sorting နဲ့ filtering လုပ်တဲ့ queries တွေစမ်းသပ်သွားပါမယ်။ 6 | 7 | ![SF1](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/sf/sf1.png) 8 | 9 | --- 10 | ``` 11 | CREATE TABLE students ( 12 | student_id INT PRIMARY KEY, 13 | name VARCHAR(50), 14 | nick_name VARCHAR(50), 15 | age INT, 16 | major VARCHAR(50) 17 | ); 18 | ``` 19 | ``` 20 | INSERT INTO students (student_id, name, nick_name, age, major) 21 | VALUES 22 | (1, 'John Doe', 'JD', 20, 'Computer Science'), 23 | (2, 'Jane Smith', 'JS', 22, 'Mathematics'), 24 | (3, 'Alice Johnson', 'AJ', 21, 'History'), 25 | (4, 'Bob Williams', 'BW', 20, 'Chemistry'), 26 | (5, 'Eva Brown', 'EB', 22, 'Biology'), 27 | (6, 'Charlie Davis', 'CD', 21, 'Physics'), 28 | (7, 'John Doe', 'JD', 20, 'Computer Science'), 29 | (8, 'Alice Johnson', 'AJ', 21, 'History'); 30 | ``` 31 | `select *` နဲ့ data တွေကိုပြန်စစ်ကြည့်နိုင်ပါတယ်။ 32 | 33 | ![SF2](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/sf/sf2.png) 34 | 35 | --- 36 | 37 | #### ORDER BY 38 | 39 | Sorting စီဖို့အတွက် SQL မှာတော့ `ORDER BY` ဆိုတဲ့ command ကိုအသုံးပြုပါတယ်။ လိုအပ်သလို `ASC` ascending, `DESC` descending options တွေကိုအသုံးပြုနိုင်ပါတယ်။ 40 | `students` table ထဲက `name` တွေကို `ORDER BY` command အသုံးပြုပြီး `ASC`option နဲ့အစဉ်လိုက်စီကြည့်ပါမယ်။ 41 | ``` 42 | SELECT * FROM students 43 | ORDER BY name ASC; 44 | ``` 45 | ![SF3](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/sf/sf3.png) 46 | 47 | --- 48 | `DESC` descending နဲ့စီမယ်ဆိုရင်တော့အခုရနေတဲ့ result `a to z` ကနေ `z to a` အဖြစ်ပြောင်းပြန်ရမှာဖြစ်ပါတယ်။ 49 | 50 | အသက် `age` column ကိုထောက်ပြီး `DESC` option နဲ့စီကြည့်ရအောင်၊ အသက်ကြီးဆုံးလူအရင်ပြဆိုတဲ့သဘောပေါ့။ 51 | 52 | ``` 53 | SELECT * FROM students 54 | ORDER BY age DESC; 55 | ``` 56 | 57 | ![SF4](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/sf/sf4.png) 58 | 59 | --- 60 | `ASC` နဲ့စီမယ်ဆိုရင်တော့ထုံးစံအတိုင်းပြောင်းပြန် ပြန်ဖြစ်သွားပြီးတော့ အငယ်ဆုံး student ကိုအရင်ပြမှာဖြစ်ပါတယ်။ 61 | 62 | 63 | #### DISTINCT 64 | `select` ဆွဲတဲ့နေရာမှာ unique ဖြစ်တဲ့ record တွေပဲလိုချင်တဲ့အချိန်မှာ `DISTINCT` ဆိုတဲ့ keyword ကိုသုံးပါတယ်။ 65 | ဥပမာ `students` table ထဲက `major` နာမည်တွေလိုချင်တယ်၊ သို့ပေမယ့် ထပ်နေတဲ့ (duplicate) record တွေမပါချင်ဘူးဆိုတဲ့အခြေအနေမှာ `DISTINCT` ကိုသုံးနိုင်ပါတယ် 66 | ``` 67 | SELECT DISTINCT major FROM students; 68 | ``` 69 | 70 | ![SF5](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/sf/sf5.png) 71 | 72 | --- 73 | #### LIMIT 74 | Table ထဲက records တွေအကုန်လုံးပါမလာချင်ဘူး၊ record ၂ခုပဲပါချင်တယ်၊ ၃ခုပဲပါချင်တယ်ဆိုတဲ့အခြေအနေမှာ `LIMIT` ခံပြီး select ဆွဲနိုင်ပါတယ်။ 75 | ``` 76 | SELECT * FROM students LIMIT 2; 77 | ``` 78 | ![SF6](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/sf/sf6.png) 79 | 80 | --- 81 | #### OFFSET 82 | select ဆွဲတဲ့နေရာမှာ records တစ်ချို့ကိုကျော်ပြီးဆွဲချင်တယ် သို့ စမှတ်ကိုပြောင်းပြီးသတ်မှတ်ချင်တယ်ဆိုရင် `OFFSET` ကိုသုံးနိုင်ပါတယ်။ query နဲ့ screenshot ကိုတွဲပြီးကြည့်မယ်ဆိုပိုသဘောပေါက်လွယ်ပါမယ်။ 83 | Records ၃ခုကိုကျော်ပြီး LIMIT ကို 2လို့ခံပြီးဆွဲမယ်ဆို result အဖြစ် 4 ကစမယ်၊ LIMIT 2 ဖြစ်တဲ့အတွက် 2 rows ပဲထုတ်သွားမှာဖြစ်ပါတယ်။ 84 | 85 | ``` 86 | SELECT * FROM students LIMIT 2 OFFSET 3; 87 | ``` 88 | 89 | ![SF7](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/sf/sf7.png) 90 | 91 | --- 92 | #### Filtering 93 | 94 | Filtering ကစိမ်းတဲ့အရာတစ်ခုတော့မဟုတ်ပါဘူး၊ အရှေ့က DQL အပိုင်းမှာ `WHERE` keyword ကိုသုံးပြီး query တွေဆွဲခဲ့ပါသေးတယ်။ Data တွေကို filter လုပ်တဲ့နေရာမှာ `WHERE` ကိုအသုံးပြုနိုင်ပါတယ်။ ဒီအပိုင်းမှာတော့ `WHERE` ကိုတစ်ချို့ commands လေးတွေပါ conjunction လုပ်ပြီးသုံးကြည့်ကြပါမယ်။ 95 | 96 | Computer Science `major` နဲ့ကျောင်းသားတွေကိုဆွဲထုတ်ကြည့်ရအောင်။ 97 | ``` 98 | SELECT * FROM students 99 | WHERE major = 'Computer Science'; 100 | ``` 101 | 102 | ![SF8](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/sf/sf8.png) 103 | 104 | --- 105 | #### LIKE 106 | LIKE ကိုလည်းအရှေ့မှာတစ်ခေါက်ပြောထားပြီးသားဖြစ်ပါတယ်။ search လုပ်မယ့်နေရာမှာသုံးပါတယ်။ နာမည်မှာ J နဲ့ စတဲ့ကျောင်းသားတွေကိုဆွဲထုတ်ကြည့်ချင်တယ်ဆိုပါစို့။ 107 | 108 | ``` 109 | SELECT * FROM students 110 | WHERE name LIKE 'J%'; 111 | ``` 112 | 113 | ![SF9](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/sf/sf9.png) 114 | 115 | --- 116 | #### BETWEEN 117 | Range condition တစ်ခုကြားထဲက data တွေကိုဆွဲထုတ်ချင်တဲ့အချိန်မှာသုံးပါတယ်။ 118 | ဥပမာ အသက် 20 နဲ့ 21 ကြားထဲကကျောင်းသားတွေကိုလိုချင်တယ်ဆိုပါစို့။ 119 | 120 | ``` 121 | SELECT * FROM students 122 | WHERE age BETWEEN 20 AND 21; 123 | ``` 124 | 125 | ![SF10](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/sf/sf10.png) 126 | 127 | --- 128 | #### Combining 129 | အထက်မှာဖော်ပြခဲ့တဲ့ sorting နဲ့ filter commands တွေကိုပေါင်းပြီးအသုံးပြုကြည့်ပါမယ်။ 130 | အသက်ကို ငယ်စဉ်ကြီးလိုက်နဲ့ Biology major ဖြစ်တဲ့ကျောင်းသားတွေကိုဆွဲထုတ်ကြည့်ပါမယ်။ 131 | ``` 132 | SELECT * FROM students 133 | WHERE major = 'Biology' 134 | ORDER BY age ASC; 135 | ``` 136 | 137 | ![SF11](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/sf/sf11.png) 138 | 139 | --- 140 | အရှေ့အပိုင်းတွေမှာ WHERE ကို AND, OR ခံပြီးသုံးတာတွေရှိခဲ့ပါတယ်။ အခု query မှာ WHERE ကို နည်းနည်းပို advance ဖြစ်တဲ့နည်းနဲ့သုံးကြည့်ပါမယ်။ 141 | 142 | Table ထဲမှာ age 22 ဖြစ်တဲ့ကျောင်းသားကိုဆွဲမယ်၊ ပြီးတော့ကျောင်းသားက Computer Science သို့ Mathematics major ဖြစ်ရမယ်။ ဒီလိုမျိုး case မှာအောက်က query လိုမျိုး `( )` ရေးပေးခြင်းက conflict ဖြစ်နိုင်မယ့်အခြေအနေကိုကာကွယ်ပေးနိုင်ပါတယ်။ 143 | 144 | ``` 145 | SELECT * FROM students 146 | WHERE (major = 'Computer Science' OR major = 'Mathematics') 147 | AND age = 22; 148 | ``` 149 | 150 | ![SF12](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/sf/sf12.png) 151 | 152 | --- 153 | Sorting & filtering အပိုင်းမှာအသုံးများတဲ့ဥပမာတွေနဲ့တကွရေးသားပေးခဲ့ပါတယ်။ တစ်ချို့အရှေ့မှာပါပြီးသား commands တွေပြန်ပါတာတွေ့ရပါမယ်။ မျက်မှန်းတန်းမိသွားစေချင်တာအပြင် conjunction လုပ်ပြီးစမ်းသုံးကြည့်စေချင်ပါတယ်။ query တစ်ခုမှာ keyword ၃ ၄ ခုထည့်ပြီး select တွေဆွဲကြည့်ခြင်းဖြင့် နားလည်ထားတဲ့အရာတွေကိုပိုမို strong ဖြစ်လာစေတဲ့အပြင် real world queries တွေနဲ့လည်းပိုနီးစပ်လာနိုင်မှာဖြစ်ပါတယ်။ 154 | -------------------------------------------------------------------------------- /sql_intro.md: -------------------------------------------------------------------------------- 1 | # Introduction to SQL 2 | 3 | Relational Database တွေကိုစီမံခန့်ခွဲဖို့အတွက် SQL, Structure Query Language ဆိုတဲ့ programming language ကိုအသုံးပြုပါတယ်။ 4 | Database ထဲမှာရှိတဲ့ data တွေကို ထုတ်ယူ၊သိမ်းဆည်း၊ပြုပြင်၊ရှင်းလင်းတာတွေကိုလုပ်နိုင်ဖို့အတွက် DBMS ကိုအသုံးပြုပါတယ်။ DBMS ကို SQL commands တွေပေးလိုက်ခြင်းဖြင့်လိုသလို စီမံနိုင်သွားမှာဖြစ်ပါတယ်။ 5 | အရှေ့မှာတုန်းက DBMS ဆိုတာဟာ user နဲ့ database ကြားထဲက software တစ်ခုဆိုပြီးရေးသားခဲ့ပါတယ်။ 6 | 7 | ထိုနည်းလည်းကောင်းပဲ SQL ဆိုတာက DBMS နဲ့ user ကြားထဲကအရာတစ်ခုပါပဲ။ SQL ဆိုတာကလည်း commands လေးတွေပါပဲ။ ဥပမာ 8 | Student table ထဲကအသက်၂၀ကျော်တဲ့ data တွေကိုဆွဲထုတ်ပေးပါ။ 9 | Student table ထဲကအသက်၃၀ကျော်တဲ့ data တွေကိုဖျက်ပေးပါ၊ စသည်ဖြင့်။ 10 | 11 | အမှန်တစ်ကယ် SQL syntax ကဒီလိုတော့မဟုတ်ဘူးပေါ့။ နောက်ပိုင်းမှာပါလာပါမယ်။ 12 | User ကပြုလုပ်ချင်တဲ့ data စီမံခန့်ခွဲမှုတွေကို SQL အသွင်ပြောင်းလဲပြီးတော့ DBMS ကိုပေးလိုက်တယ်၊ DMBS ကနေတစ်ဆင့် data တွေကိုပြင်ဆင်ပြောင်းလဲမှုတွေလုပ်ဆောင်နိုင်ပါတယ်။ 13 | 14 | ## What is a Query? 15 | 16 | Relational Database ထဲက data တွေကိုစီမံခန့်ခွဲဖို့အတွက် DBMS ကိုပေးလိုက်တဲ့ commands တွေကို SQL လို့ခေါ်ပါတယ်။ 17 | Query တွေကိုအသုံးပြုပြီးတော့ data တွေကိုလိုအပ်သလို filter, sorting, calculation တွေလုပ်ပီး ဆွဲထုတ်နိုင်တဲ့အပြင် data အသစ်သိမ်းဆည်းခြင်း၊ ရှိပြီးသား data တွေကိုပြုပြင်ခြင်း၊ ဖယ်ရှားခြင်းတို့ကိုလည်းလုပ်ဆောင်နိုင်ပါတယ်။ 18 | Data ဆွဲထုတ်တဲ့နေရာမှာ Table တစ်လုံးထဲကနေလည်းဆွဲထုတ်တာလည်းရှိသလို တစ်ခုထက်ပိုတဲ့ Tables တွေကိုချိတ်ဆက်ပြီးတော့လည်းထုတ်နိုင်ပါတယ်။ 19 | 20 | ## SQL Standards 21 | 22 | DBMS software ပေါ်မူတည်ပြီးတော့ SQL Standard ကလည်းအနည်းငယ်ကွဲပြားသွားနိုင်တာကို ဒီနေရာမှာထည့်သွင်းရေးသားချင်ပါတယ်။ 23 | ဘာသာစကားတစ်ခုတောင်မှ နေရာဒေသပေါ်မူတည်ပြီး ခေါ်ဆိုပုံတွေ၊ လေယူလေသိမ်းတွေကွဲပြားသွားသလိုပဲ SQL မှာလည်း DBMS software ကိုလိုက်ပြီးတော့ syntax ရေးနည်း၊ရေးဟန်တွေအနည်းငယ်ကွဲပြားတာမျိုးရှိတတ်ပါတယ်။ 24 | SQL Dialect လို့လည်းခေါ်နိုင်ပါတယ်။ DBMS software ဆိုတာကတော့ company တွေကထုတ်တာတွေပေါ့ဗျာ။ ဥပမာ 25 | - MySQL 26 | - Oracle 27 | - Microsoft SQL Server 28 | - PostgreSQL စသည်ဖြင့်ပေါ့။ 29 | 30 | လက်တွေ့ဥပမာလေးတစ်ခုနဲ့ပြရရင် student table ထဲက hlaing ဆိုတဲ့နာမည်ရှိတဲ့ကျောင်းသားကိုဆွဲထုတ်ချင်တယ်ဆိုပါစို့ 31 | MySQL မှာဆိုရင် 32 | ``` 33 | SELECT * FROM students WHERE name = 'hlaing' 34 | ``` 35 | hlaing ဆိုတဲ့နာမည်ကို single quote ခံလည်းရသလို "hlaing" ဆိုပြီး double quote နဲ့လည်းဆွဲလို့ရပါတယ်။ 36 | သို့ပေမယ့် PostgreSQL မှာတော့ single quote ပဲအသုံးပြုနိုင်မယ်။ ဒါမျိုးအနည်းငယ်ကွဲပြားမှုလေးတွေရှိနိုင်ပါတယ်။ 37 | နောက်ပြီး function နာမည်အချို့ပေါ့၊ အလုပ်လုပ်ပုံတူပေမယ့် naming လေးတွေကွဲပြားနိုင်ပါတယ်။ 38 | 39 | ## SQL Naming Conventions 40 | Programming တစ်ခုခုရထားပြီးသားဆိုရင်တော့ naming conventions ကိုမစိမ်းလောက်ဘူးထင်ပါတယ်။ SQL မှာလည်း query တွေရေးတဲ့အချိန်သတ်မှတ်လိုက်တဲ့ naming words တွေနဲ့ပတ်သတ်ပြီးလိုက်နာသင့်တဲ့ scheme လေးတွေရှိပါတယ်။ 41 | နောက်ပိုင်း query ရေးရင်တော့ပိုသိလာမှာဆိုတော့ ဒီအပိုင်းမှာအကြမ်းဖျင်းပဲရေးလိုက်ပါမယ်။ 42 | - နားလည်ရလွယ်ကူမယ့် naming ပေးရန်။ 43 | - Reserve keyword တွေဖြစ်တဲ့ SELECT, INSERT, UPDATE စတဲ့ keyword တွေကိုရှောင်ရှားရန်။ 44 | - Naming ပေးတဲ့အခါ space နဲ့ special characters တွေကိုရှောင်ရှားရန်။ 45 | - လိုအပ်ပါက space အစား underscore သို့ Camel Case အသုံးပြုရန်။ 46 | - ကိုယ်သုံးတဲ့ casing ကို consistent ဖြစ်အောင်သုံးရန်။ 47 | - တစ်နေရာမှာ underscore, တစ်နေရာမှာ camel case, နောက်တစ်နေရာမှာ snake case ဆိုရင် readability ညံ့စေတဲ့အပြင် query ကိုရှုပ်ထွေးစေပါတယ်။ 48 | 49 | အရှေ့အပိုင်းမှာ Table, Row, Column ကို intro ဝင်ခဲ့ပါတယ်။ အခုထပ်ပီးရှင်းလင်းပေးသွားပါမယ်။ 50 | 51 | ### Table 52 | SQL မှာ data တွေသိမ်းဆည်းဖို့အတွက် table format ကိုအသုံးပြုပါတယ်။ Table တစ်ခုမှာ rows နဲ့ columns တွေပါဝင်ပါတယ်။ row တစ်ကြောင်းခြင်းဆီတိုင်းကို record တစ်ခုအဖြစ်သတ်မှတ်လို့ရနိုင်ပြီး column ဆိုတာကတော့ record ထဲမှာရှိတဲ့ data attribute/field ကိုဆိုလိုခြင်းဖြစ်ပါတယ်။ Table format နဲ့သိမ်းဆည်းခြင်းအားဖြင့် data တွေကိုစီမံရတာပိုမိုလွယ်ကူစေပါတယ်။ CREATE TABLE ဆိုတဲ့ SQL keyword ကိုအသုံးပြုပြီးတော့ Table တည်ဆောက်နိုင်ပါတယ်။ 53 | 54 | ### Row 55 | Row ဆိုတာ record ပါပဲ။ table တစ်ခုထဲမှာရှိတဲ့ rows တိုင်းဟာ record instance တစ်ခုခြင်းဆီအဖြစ်ကိုယ်စားပြုပါတယ်။ row တစ်ခုမှာလည်း column လို့ခေါ်တဲ့ သက်ဆိုင်ရာ attribute တွေပါဝင်ပါတယ်။ INSERT, UPDATE, DELETE ဆိုတဲ့ keyword တွေကိုအသုံးပြုပြီး row တွေကို သိမ်းဆည်း၊ ပြုပြင်၊ ဖယ်ရှားနိုင်ပါတယ်။ 56 | 57 | ### Columns 58 | Row ထဲမှာရှိတဲ့ attribute/field ဖြစ်ပါတယ်။ field တစ်ခုခြင်းဆီတိုင်းဟာသိမ်းဆည်းတဲ့ data ပေါ်မူတည်ပြီးတော့ data type တွေလည်းကွဲပြားနိုင်ပါတယ်။ ဥပမာနာမည်ဆို text, အသက်ဆို integer, ရက်ဆို date စသည်ဖြင့်။ 59 | 60 | #### Student Table 61 | ID Name Age 62 | 1 John 18 63 | 2 Sarah 17 64 | 3 David 16 65 | ဥပမာ Table တစ်ခုပါ။ 66 | 1,2,3 ဆိုတဲ့ row ၃ခုရှိပြီးတော့ row တစ်ခုခြင်းဆီတိုင်းမှာ ID, Name, Age ဆိုတဲ့ column တွေပါဝင်ပါတယ်။ 67 | row, column အားလုံးပါဝင်တဲ့ဒီတစ်ခုလုံးကိုတော့ table ဆိုပြီးခြုံငုံသတ်မှတ်နိုင်ပါတယ်။ 68 | -------------------------------------------------------------------------------- /transaction.md: -------------------------------------------------------------------------------- 1 | ## Transactions 2 | 3 | Database ပေါ်ကို execute လုပ်သွားမယ့် operation တစ်ခု သို့ တစ်ခုထပ်ပိုတဲ့ operation sequence set တစ်ခုကို transaction လို့သတ်မှတ်နိုင်ပါတယ်။ Transaction တွေရဲ့ပုံစံက All or Nothing ဖြစ်ပါတယ်။ ဥပမာ TableA ကို Insert operation, TableB ကို Update operation လုပ်မယ့် transaction တစ်ခုရှိတယ်ဆိုပါစို့။ နှစ်ခုလုံးရဲ့ insert & update operation က success ဖြစ်ရမယ်။ Partial success, partial failure state ကိုလက်မခံဘူး၊ All or nothing result ပဲဖြစ်သွားမှာဖြစ်ပါတယ်။ ပိုပြီးနားလည်ရလွယ်အောင် အောက်မှာ query တွေ run ပြပြီး နမူနာတွေထပ်ပေးထားပါတယ်။ 4 | 5 | Query တွေမ run ခင်မှာ Transactions အကြောင်းရေးပြီဆိုမပါလို့မဖြစ်တဲ့ `ACID` property ကိုအရင်ထည့်ရေးချင်ပါတယ်။ Transaction ရယ်လို့ဖြစ်လာပြီဆို Atomicity, Consistency, Isolation, and Durability ဆိုတဲ့ key characteristic တွေပါဝင်ပါတယ်။ 6 | 7 | #### Atomicity 8 | Transactions တွေက atomic ဖြစ်ပါတယ်။ ပါဝင်တဲ့ operation sequences တွေအားလုံး success ဖြစ်ရင်ဖြစ်၊ partial failure တစ်ခုပါတာနဲ့ အားလုံးဟာ roll back ပြန်ဖြစ်သွားပါမယ်။ 9 | 10 | #### Consistency 11 | Before and after Transactions execution တွေမှာ data တွေကမှန်ကန်စွာကျန်ရှိနေခဲ့ရမယ်၊ partial failure တစ်ခုခုဖြစ်သွားရင် data consistency ကိုထိခိုက်နိုင်ပါတယ်၊ ဆိုတော့ somehow related with above atomicity property. 12 | 13 | #### Isolation 14 | Transaction တစ်ခုနဲ့တစ်ခုအပေါ်မှာမှီခိုဆက်စပ်ခြင်းရှိမနေဘဲနဲ့ concurrently execution လုပ်နိုင်မယ်။ 15 | 16 | #### Durability 17 | Transaction execution (commit) လုပ်ပြီးသွားတာနဲ့ system failure, power outage တွေရှိသည့်တိုင်အောင် data တွေ persist ဖြစ်နေမယ်။ 18 | 19 | Geeksforgeeks က ဒီပုံလေးနဲ့ဆိုပိုပြီးမြင်သာသွားမယ်ထင်ပါတယ်။ 20 | 21 | 22 | ![Credit : GeeksforGeeks](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/tran/tr8.png) 23 | 24 | 25 | ACID properties ကိုအတိုချုပ်ရေးထားပေမယ့်အသေးစိတ်ကို ဒီမှာဝင်ဖတ်ကြည့်လို့ရပါတယ်။ 26 | https://www.geeksforgeeks.org/acid-properties-in-dbms/ 27 | 28 | ### Sample Queries 29 | 30 | Transaction query နမူနာလေးတွေစမ်းရေးကြည့်သွားပါမယ်။ 31 | 32 | Transaction တစ်ခုစဖို့အတွက် `BEGIN` ဆိုတဲ့ keyword ကိုသုံးသွားပါမယ်။ 33 | ``` 34 | BEGIN; 35 | INSERT INTO products VALUES(10, 'Energy Drink', 'Electronics', 20, 50, 'SupplierA'); 36 | ``` 37 | `products` table ထဲကို data တစ်ကြောင်းသွင်းပါမယ်။ ရလဒ်ကိုအောက်ပါအတိုင်းကြည့်နိုင်ပါတယ်။ 38 | 39 | ![tran](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/tran/tr1.png) 40 | 41 | BEGIN နဲ့ transaction တစ်ခုစထားတာဖြစ်တဲ့အတွက် သွင်းလိုက်တဲ့ record ကို `ROLLBACK` လုပ်ပြီး `undo` ပြန်လုပ်နိုင်ပါတယ်။ 42 | 43 | ![tran](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/tran/tr2.png) 44 | 45 | ID 10 ပြန်ပျောက်သွားတာကိုမြင်ရပါမယ်။ 46 | 47 | သွင်းဖို့သေချာသွားပြီဆိုရင်တော့ `COMMIT ` ကိုသုံးပြီးတော့ finalize လုပ်လိုက်လို့ရပါပြီ။ 48 | 49 | ![tran](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/tran/tr3.png) 50 | 51 | UPDATE operation နှစ်ခုပါတဲ့ transaction တစ်ခု run ကြည့်ပါမယ်။ 52 | ``` 53 | BEGIN; 54 | 55 | UPDATE products SET price = price + 100 WHERE category = 'Electronics'; 56 | UPDATE products SET price = price + 100 WHERE category = 'Clothing'; 57 | 58 | COMMIT; 59 | ``` 60 | ![tran](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/tran/tr4.png) 61 | 62 | မ run ခင်က data တွေနဲ့ပြန်ယှဉ်ကြည့်မယ်ဆိုသက်ဆိုင်ရာ category တွေမှာ price 100 ထပ်ပေါင်းသွားတာကိုမြင်ရပါမယ်။ 63 | 64 | #### Transactions with Savepoints 65 | 66 | Transaction ကို `SAVEPOINT ` တွေသုံးပြီးတော့လည်းအသုံးပြုနိုင်ပါတယ်။ မိမိလိုတဲ့ `SAVEPOINT` ကိုအောက်ပါအတိုင်း `ROLLBACK` လည်းလုပ်နိုင်ပါတယ်။ 67 | 68 | ``` 69 | SAVEPOINT before_update; 70 | UPDATE products SET price = price + 100 WHERE category = 'Electronics'; 71 | 72 | SAVEPOINT before_second_update; 73 | UPDATE products SET price = price + 100 WHERE category = 'Clothing'; 74 | 75 | -- Rollback to the second savepoint 76 | ROLLBACK TO before_second_update; 77 | 78 | COMMIT; 79 | ``` 80 | ![tran](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/tran/tr6.png) 81 | 82 | ဒီ transaction မှာဆို `before_second_update` အထိပြန် `ROLLBACK` သွားပြီး clothing category အတွက် effect ဖြစ်သွားတော့မှာမဟုတ်ပါဘူး။ 83 | 84 | ![tran](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/tran/tr7.png) 85 | 86 | ### Tips when using transactions 87 | Transactions တွေသုံးတဲ့အချိန်မှာ 88 | - တတ်နိုင်သလောက် simple ဖြစ်နိုင်ရင်ပိုကောင်းပါတယ်။ 89 | - Long running transactions တွေဟာ concurrency နဲ့ performance issues ရှိနိုင်တာကိုသတိချပ်ထားရပါမယ်။ 90 | - လိုအပ်သလို error handling exceptions တွေလည်းထည့်သုံးသင့်ပါတယ်။ 91 | 92 | Data integrity နဲ့ consistency ကောင်းဖို့အတွက် Transactions တွေကအရေးပါတဲ့အစိတ်အပိုင်းတစ်ခုဖြစ်ပါတယ်။ ဒီအပိုင်းနဲ့ပတ်သတ်လို့ထပ်လေ့လာစရာအများကြီးကျန်ပါသေးတယ်၊ သို့သော်ဒီနေရာကနေလမ်းစတစ်ခုရသွားဖို့မျှော်လင့်ပါတယ်။ 93 | -------------------------------------------------------------------------------- /trigger.md: -------------------------------------------------------------------------------- 1 | ## Triggers 2 | 3 | SQL ရဲ့ data manipulation action (INSERT, UPDATE, DELETE) ပေါ်မှာမူတည်ပြီး automatic query တွေ ထပ်ပြီး run ချင်တဲ့နေရာမျိုးမှာ Trigger တွေကိုအသုံးပြုနိုင်ပါတယ်။ ဥပမာ `student` ဆိုတဲ့ table ထဲကို `INSERT` ထည့်တဲ့အချိန်မှာ `student_logs` table ထဲကို data ထပ်သွင်းနိုင်ဖို့ trigger ကိုအသုံးပြုပြီး define လုပ်ထားနိုင်ပါတယ်။ 4 | 5 | Trigger နှစ်မျိုးရှိပါတယ်။ 6 | 7 | #### Before Triggers 8 | - Before ကတော့ မူလ query event execute မလုပ်ခင်မှာ triggering လုပ်ပါတယ်။ 9 | - များသောအားဖြင့် DB ထဲမှာပြောင်းလဲမှုတွေမလုပ်ခင် validation လုပ်ဖို့အတွက်အသုံးပြုပါတယ်။ 10 | 11 | #### After Triggers 12 | - After ကတော့မူလ query event က execute လုပ်ပြီးတော့မှ triggering လုပ်ပါတယ်။ 13 | - DB ထဲမှာပြောင်းလဲမှုတွေပြီးမှ trigger လုပ်တဲ့အတွက်များသောအားဖြင့် logging, reporting တို့အတွက်အသုံးပြုပါတယ်။ 14 | 15 | Schema ကတော့အောက်ပါအတိုင်းဖြစ်ပါတယ်။ 16 | ``` 17 | CREATE TRIGGER trigger_name 18 | BEFORE INSERT ON table_name 19 | FOR EACH ROW 20 | BEGIN 21 | -- Trigger statements 22 | END; 23 | ``` 24 | 25 | နမူနာ query လေးတွေစမ်းလုပ်ကြည့်ပါမယ်။ 26 | 27 | `products` table ထဲကို data update လုပ်တဲ့အချိန်မှာ `price` column ရဲ့ တန်ဖိုးကို 0 အောက်မရောက်ဖို့ validation check လုပ်ကြည့်ပါမယ်။ Execute မလုပ်ခင်မှာ check လုပ်ချင်တာဖြစ်တဲ့အတွက် `BEFORE` ကိုသုံးနိုင်ပါတယ်။ 28 | 29 | ``` 30 | DELIMITER // 31 | 32 | CREATE TRIGGER check_price 33 | BEFORE UPDATE ON products 34 | FOR EACH ROW 35 | BEGIN 36 | IF NEW.price < 0 THEN 37 | SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Price cannot be negative'; 38 | END IF; 39 | END; // 40 | 41 | DELIMITER ; 42 | ``` 43 | 44 | ![trigger](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/tri/tr1.png) 45 | 46 | --- 47 | 48 | `DELIMITER` ထည့်သုံးရခြင်းကတော့ trigger လို stored procedure တွေမှာ statements တွေတစ်ခုထက်ပိုပါနိုင်ပြီး `;` အများအပြားရှိနိုင်ပြီး syntax error ဖြစ်နိုင်တဲ့အတွက် `DELIMITER` ကိုသုံးပြီးတော့ ယာယီအစားထိုးထားလိုက်ခြင်းဖြစ်ပါတယ်။ DELIMITER အကြောင်းအသေးစိတ်ကိုအောက်ကလင့်ခ်မှာဆက်ဖတ်နိုင်ပါတယ်။ 49 | https://www.mysqltutorial.org/mysql-stored-procedure/mysql-delimiter/ 50 | 51 | ဆောက်လိုက်တဲ့ trigger ကိုဒီလိုပြန်ကြည့်နိုင်ပါတယ်။ 52 | 53 | ##### Schema 54 | ``` 55 | SHOW TRIGGERS WHERE `Table` = 'your_table_name'; 56 | ``` 57 | `products` table မှာဆောက်ခဲ့တာဖြစ်တဲ့အတွက် 58 | ``` 59 | SHOW TRIGGERS WHERE `Table` = 'products'; 60 | ``` 61 | ပြန်စစ်တဲ့အနေနဲ့ `price` column ကို negative value ထည့်ပြီး query တစ်ခု execute လုပ်ကြည့်ပါမယ်။ 62 | ``` 63 | UPDATE products SET price = -100 WHERE product_id = 1; 64 | ``` 65 | 66 | ![trigger](https://raw.githubusercontent.com/HlaingTinHtun/SQL-101/main/assets/queries/tri/tr2.png) 67 | 68 | ဆောက်ထားတဲ့ `check_price` trigger ကဝင်လာပြီး `error` ပြပေးသွားတာကိုမြင်ရမှာဖြစ်ပါတယ်။ 69 | 70 | 71 | နောက်ထပ်နမူနာတစ်ခုအနေနဲ့ `employee` table ကိုပြောင်းလဲမှုပြုလုပ်တိုင်းမှာ table နောက်တစ်ခုမှာ `audit` logs တွေသိမ်းထားချင်တယ်ဆိုအောက်ပါအတိုင်း `AFTER` trigger တစ်ခုဖန်တီးထားနိုင်ပါတယ်။ သဘောတရားကိုနားလည်သွားပြီလို့ယူဆတဲ့အတွက် Table နောက်တစ်လုံးအသစ်ထပ်မဆောက်တော့ပါဘူး၊ မိမိဘာသာလေ့ကျင့်တဲ့အနေနဲ့စမ်းလုပ်ကြည့်လို့လည်းရပါတယ်။ 72 | 73 | - `employee_audit` table အသစ်တစ်လုံးဆောက်မယ်။ 74 | - `employees` table ပေါ်မှာအောက်က query နဲ့ trigger တစ်ခုဖန်တီးမယ်။ 75 | - `employees` table မှာ `UPDATE` query တစ်ခု run ကြည့်မယ်။ 76 | - ဒါဆိုရင် trigger ကအသက်ဝင်သွားပြီး audit table မှာ data အသစ်ထည့်သွားတာကိုမြင်နိုင်မှာဖြစ်ပါတယ်။ 77 | 78 | ``` 79 | DELIMITER // 80 | 81 | CREATE TRIGGER log_employee_changes 82 | AFTER UPDATE ON employees 83 | FOR EACH ROW 84 | BEGIN 85 | INSERT INTO employee_audit (employee_id, action, timestamp) 86 | VALUES (OLD.employee_id, 'UPDATE', NOW()); 87 | END; // 88 | 89 | DELIMITER ; 90 | ``` 91 | 92 | ဒီလောက်ဆိုရင် `triggers` တွေအကြောင်းကိုအခြေခံအားဖြင့်နားလည်သွားမယ်လို့ထင်ပါတယ်၊ project domain ပေါ်မူတည်ပြီး trigger တွေဟာ ယခုထက်ပိုပြီး complex ဖြစ်နိုင်ပါတယ်။ များသောအားဖြင့်လက်ရှိအသုံးပြုနေတဲ့ programming language နဲ့ framework တွေမှာ support ရှိတဲ့အတွက် `trigger` တွေသီးသန့်မဖန်တီးဘဲ `application` layer မှာတင် DB transaction `before` & `after` hook တွေနဲ့ develop လုပ်နိုင်ပါတယ်။ သို့ပေမယ့်လည်း `trigger` တွေကိုအသုံးပြုမယ့်အခြေအနေတွေလည်းရှိနေနိုင်သေးပါတယ်။ 93 | 94 | Trigger တွေသုံးမယ်ဆို 95 | - Performance overhead မဖြစ်အောင်ဂရုစိုက်ပြီး တတ်နိုင်သမျှ lightweight ဖြစ်အောင်ဖန်တီးသင့်ပါတယ်။ 96 | - Trigger တွေက ပုံမှန် query တွေထက်အနည်းငယ်ဖတ်ရခက်နိုင်တဲ့အတွက် over complex မဖြစ်အောင်၊ ရေရှည်မှာ maintainability issues တွေမရှိအောင် review လုပ်ထားသင့်ပါတယ်။ သင့်တော်တဲ့ comments တွေနဲ့တစ်ပါတည်း document လုပ်ထားသင့်ပါတယ်။ 97 | - Triggers တွေဆောက်ပြီးတာနဲ့ ကိုယ်လိုအပ်သလို trigger ဖြစ်ရဲ့လားဆိုတာကိုလည်း Test သေချာလုပ်ထားသင့်ပါတယ်၊ မဟုတ်ရင် `triggers` တွေကအတော်လေး risk ကြီးပါတယ်။ 98 | 99 | Conclude လုပ်ရမယ်ဆို `triggers` တွေကိုအသုံးပြုခြင်းဖြင့် DB ဘက်ခြမ်းမှာတင် automation tasks တွေဖန်တီးနိုင်တဲ့အတွက်အလွန်အသုံးဝင်နိုင်သလို best practices တွေမလိုက်နာရင်လည်း database အတွက် risk များတတ်နိုင်တဲ့အတွက်ကြောင့်ဂရုပြုပြီးဖန်တီးသင့်ပါတယ်။ 100 | --------------------------------------------------------------------------------