SQLطريقة تصميم قاعدة بيانات من الصفر
- معرفة المعلومات الأساسية التي يجب تخزينها في المشروع
- مرحلة تحديد كيفية تخزين المعلومات في قاعدة البيانات
- مرحلة تصميم و إنشاء قاعدة البيانات
- مرحلة إدخال البيانات في قاعدة البيانات
- أمثلة شاملة حول استرجاع البيانات
معرفة المعلومات الأساسية التي يجب تخزينها في المشروع
عندما يطلب منك العميل تصميم قاعدة بيانات لأي مشروع و لنفرض أنه يريد قاعدة بيانات لمدونة, عليك معرفة ما الذي يريد من هذه المدونة بالضبط حتى تعرف كيف تبني قاعدة البيانات الخاصة بها و في حال وجدت أنه لا يعرف كل المعلومات التي يجب تخزينها - و هذا شيء طبيعي جداً - يمكنك أن تقترح عليه أفكار مرت معك سابقاً لتساعده في تحديد ما يريده بالضبط.
فمثلاً قد تجد العميل يقول لك: "أريد فقط مدونة لأنشر بها مقالات كل فترة".
هذه المعلومة لا تكفي حتى تبني قاعدة البيانات بالشكل الذي يتخيله العميل, لذلك هنا من الطبيعي أن تبدأ بسؤاله بشكل أدق عن الذي يريد أن تحتويه المدونة من مميزات حتى تعرف كيف ستبني قاعدة بيانات المدونة و إليك بعض الأسئلة التي قد تطرحها عليه لتعرف كيف ستبنيها:
- هل ستكون الشخص الوحيد الذي يمكنه كتابة المقالات؟
- هل تريد أن تكون مسؤول عن تعيين المدونيين و الموافقة على المقالات التي سينشروها؟
- هل تريد جعل زوار الموقع قادرين على وضع تعليقات على المقالات؟
- هل تريد إجبار الزوار على تسجيل الدخول حتى يتمكنوا من وضع التعليقات؟
- هل تريد تريد جعل الشخص المسجل في الموقع يصله رسالة على بريده الإلكتروني عندما تنشر مقالات جديدة؟
- هل سيكون المستخدم قادر على وضع صورة شخصية؟
- هل سيكون المستخدم قادر على وضع نبذة تعريفية عن نفسه؟
- ما هي الطرق التي تريد إعمتادها لجعل المستخدم يسترجع حسابه في حال نسي كلمة مروره؟
- هل سيكون المستخدم قادر على تسجيل الدخول بواسطة حسابه في فيسبوك أو تويتر؟
يمكنك أن تطرح عليه عدد غير محدد من الأسئلة و من بعدها يمكنك البدء بوضع خطة لبناء قاعدة البيانات الخاصة بهذه المدونة.
مرحلة تحديد كيفية تخزين المعلومات في قاعدة البيانات
بعدما أبلغك العميل بكل تفاصيل مشروعه, يصبح عملك الآن هو معرفة كيف ستبني قاعدة البيانات الخاصة بهذا المشروع حتى تخزن المعلومات التي سيدخلها أي شخص يستخدم المدونة بشكل صحيح و مرتب.
لنفترض أن العميل أراد حفظ المعلومات التالية في المدونة:
- معلومات كل مستخدم (إسمه, إسم المستخدم الخاص به, كلمة المرور, بريده الإلكتروني, تاريخ ميلاده, رقم هاتفه, جنسه, صورته, إسم بلده, دوره في المدونة, تعليقاته).
- معلومات كل مقال (عنوانه, محتواه, تصنيفه, إسم الكاتب, تاريخ نشره, هل يسمح بوضع تعليقات عليه أم لا).
أهم شيء عليك الإنتباه له هو أنه المعلومات التي قمنا بتدوينها على سطرين لا تعني أبداً أنه يجب توزيع هذه المعلومات على جدولين فقط.
الآن يجب معرفة ما هي البيانات التي يمكن أن نجزءها لعدة أعمدة و أنواعها و ما هي البيانات التي قد تتكرر في كل سطر حتى نتجنب وضع قيم مكررة أو حقول فارغة.
1- إسم الشخص
إسم الشخص يتألف في العادة من إسم الشخص و إسم عائلته.
لذا إسم الشخص سيتم وضعه في عامودين كالتالي:
- العمود الأول إسمه
first_name
و نوعه VARCHAR. - العمود الأول إسمه
last_name
و نوعه VARCHAR.
ملاحظة: لو أراد العميل تخزين إسم الأب أيضاً, يمكن إضافة عمود ثالث إسمه father_name
و نوعه VARCHAR أيضاً.
2- إسم المستخدم
إسم المستخدم username
الخاص بكل شخص يجب أن يكون نوعه VARCHAR و UNIQUE لأنه لا يجب وجود أكثر من شخص عندهم نفس إسم المستخدم.
3- كلمة المرور
كلمة المرور أو كلمة السر password
الخاصة بكل شخص يمكن حفظها بعدة أشكال مع الإشارة إلى أننا دائماً نحفظها بشكل مشفر حتى لا يتمكن أي أحد من معرفتها.
على حسب نوع التشفير الذي تختاره في مشروعك تقوم بتحديد خصائص العمود الذي ستحفظ فيه كلمات المرور المشفرة.
إذا افترضنا أننا سنعتمد على تشفير إسمه MD5 فهنا سيكون عدد أحرف كل كلمة مرور مشفرة هو 32 حرف بالضبط مهما كان حجم كلمة المرور الأصلية.
لذلك سنقوم بجعل نوع العمود CHAR و تحديد أنه يتألف من 32
حرف بالضبط لأن حقوله دائماً ستحتوي على هذا العدد من الأحرف.
4- تاريخ ميلاد الشخص
تاريخ ميلاد الشخص birthdate
يجب أن يكون نوعه DATE.
5- رقم هاتف الشخص
رقم هاتف الشخص phone
يمكن جعل نوعه INT و لكن هل نحن بحاجة لأن يكون كذلك؟
الجواب هو كلا, لأننا لن نجري عليه أي عملية خاصة بالأرقام و نريد أن يتم حفظه كما تم إدخاله بالضبط و هذا الأمر مستحيل إن كان نوع العمود INT.
فمثلاً, إن كان رقم هاتف المستخدم قد يتضمن رموز مثل +961711731343
و هذا الأمر ممنوع في حال كان نوع العمود INT.
أيضاً قد يتضمن اصفاراً من الناحية اليسرى مثل 00961711731343
و هذا الأمر ممنوع كذلك في حال كان نوع العمود INT.
لهذا السبب العمود phone
يجب أن يكون نوعه VARCHAR لأنه سيضمن حفظ الرقم كما تم إدخاله.
6- جنس الشخص
جنس الشخص يمكنك أن تفعله بطريقتين على حسب حاجتك:
يمكنك تسمية العمود الخاص بجنس الشخص is_male
و تجعل نوعه BOOLEAN و عندها إذا كان المستخدم ذكر تخزن القيمة True و إذا كان المستخدم أنثى تخزن القيمة False.
الطريقة الثانية هي بأن تنشئ جدول خاص إسمه genders
لتخزن فيه أنواع الجنس و عندها لاختيار نوع الجنس تختار رقم id
الجنس فقط.
ملاحظة: سنعتمد هذه الطريقة لجعلك تعتاد على التعامل مع عدد أكبر من الجداول و لأنها تتيح لنا إضافة المزيد من الخصائص, فمثلاً يمكننا جعل الجدول genders
يحتوي على إسم الجنس باللغة العربية و باللغة الإنجليزية.
7- صورة الشخص
صور جميع المستخدمين يفضل دائماً إنشاء جدول خاص لها و يمكنك تسميته photos
.
في هذا الجدول يمكنك تحديد الكثير من المعلومات, مثل المكان الذي سيتم فيه حفظ الصورة (أي رابط الوصول لها), إسم الصورة, حجمها, نوعها إلخ..
في الجدول photos
يجب أن تضع عمود خاص لتضع id
الشخص الذي هو صاحب هذه الصورة حتى تربطها به.
8- بلد الشخص
بلد الشخص قد يتكرر بشكل كبير, لذا لتجنب تكرار إسم البلد سنقوم بإنشاء جدول إسمه countries
و فيه نضع أسماء البلدان, و عندها لتحديد بلد أي مستخدم نضع رقم id
البلد.
9- دور الشخص
دور الشخص في المدونة سيتكرر حتماً و بشكل كبير, لذا جميع الأدوار التي ممكن إعطاءها للمستخدمين سنضع أسماءها في جدول خاص إسمه roles
و عندها لتحديد دور أي مستخدم نضع رقم id
الدور الذي سنعطيه له.
10- تعليقات الشخص
تعليقات الأشخاص تتطلب معاملة خاصة لإدارتها لأنه يمكن للمستخدم أن يضع أكثر من تعليق على نفس المقال و يمكن له أن يضع تعليق يكون بمثابة رد على تعليق مستخدم آخر. لذا الحل الأفضل و الأمثل لحفظ التعليقات هو إنشاء جدول خاص إسمه comments
و هذا الجدول نجعله قادر على ربط التعليقات نفسها ببعضها بأسلوب Self Join حتى نتمكن من جعل التعليقات تابعة لبعضها و إظهارها كردود.
12- عنوان المقال
عنوان المقال title
يجب أن يكون نوعه VARCHAR.
13- محتوى المقال
محتوى المقال content
يجب أن يكون نوعه VARCHAR كبير جداً أو أي نوع نصي يمكن أن يتقبل أكبر عدد ممكن من الأحرف.
13- تصنيف المقال
تصنيف المقال قد يتكرر بشكل كبير, لذا لتجنب تكرار إسم التصنيف سنقوم بإنشاء جدول إسمه categories
و فيه نضع أسماء التصنيفات, و عندها لتحديد تصنيف أي مقال نضع رقم id
الصنف الذي يعتبر المقال تابع له.
14- تاريخ نشر المقال
تاريخ النشر publishing_date
يجب أن يكون نوعه DATE.
15- إمكانية التعليق أم لا
يمكنك تسمية العمود الخاص بالسماح بوضع تعليقات أم لا are_comments_enabled
و تجعل نوعه BOOLEAN و عندها إذا كان يسمح بوضع تعليقات تخزن القيمة True و إذا كان لا يسمح تخزن القيمة False.
مرحلة تصميم و إنشاء قاعدة البيانات
الشكل العام للجداول التي سننشئها و التي سنربطها ببعضها سيكون كالتالي.
الآن سنقوم بكتابة الأوامر التي ستنشئ لنا الجداول بالإضافة إلى تعيين المفاتيح الرئيسية و الأجنبية.
ملاحظة: المفاتيح الأجنبية ( Foreign Keys ), الفهارس ( Indexes ) و القيود ( Constraints ) قمنا بتعريفها بعد إنشاء جميع الجداول.
الإستعلام
بعد تنفيذ الإستعلام السابق في phpMyAdmin سيتم إنشاء قاعدة البيانات blog
و إنشاء الجداول بداخلها.
قم بالنقر على إسم قاعدة البيانات blog
من القائمة اليسرى حتى تبدأ بالتعامل معها و تطبيق ما ستتعلمه في هذا الدرس.
مرحلة إدخال البيانات في قاعدة البيانات
عند إدخال البيانات يجب أن تتعامل معها بمنطقية و أن تبدأ بإدخال البيانات الأساسية التي يجب وجودها حتى تتمكن من إدخال البيانات الأخرى التي تعتمد عليها, و إليك ما نقصده:
بالنسبة لإدخال معلومات مستخدم جديد, فإن أي مستخدم سيتم إضافته يجب أن يختار رقم الجنس gender_id
من الجدول genders
و رقم الدور role_id
من الجدول roles
لذلك يجب إدخال معلومات هذين الجدولين قبل محاولة إدخال معلومات أي مستخدم.
بالنسبة للمقالات, فإن أي مقال نضيفه يجب أن يكون مرتبط برقم id
مستخدم محدد من الجدول users
(كاتب المقال) و رقم id
تصنيفه من الجدول categories
(التصنيف الذي ينتمي إليه المقال). لذلك وجود المستخدم و تصنيفات المقال أساسي حتى تتمكن من إضافة مقال جديد مرتبط بهم.
بالنسبة للتعليقات, فإن أي تعليق نضيفه يجب أن يكون مرتبط برقم id
مستخدم محدد من الجدول users
(صاحب التعليق) و رقم id
مقال محدد من الجدول posts
(المقال الذي يوضع التعليق عليه). لذلك وجود المستخدم و المقال أساسي حتى تتمكن من إضافة تعليق جديد مرتبط بهم.
بالنسبة للصور, بما أن أي صورة تضيفها يجب أن تكون مربطة برقم id
مستخدم محدد من الجدول users
(صاحب الصورة) فهذا يعني أنه يجب إضافة مستخدم قبل إضافة صورة له و هكذا.
خلاصة
- يجب إدخال معلومات الجداول
genders
وroles
وcategories
في البداية لأن الجداول الأخرى تعتمد عليهم. - بعدها يجب إدخال معلومات الجدول
users
لأنه يصبح بإمكانك إضافة مستخدمين. - بعدها يمكنك إذا شئت إدخال معلومات الجدول
photos
لأنه يصبح بإمكانك إضافة صور للمستخدمين. - بعدها يمكنك إذا شئت إدخال مقالات في الجدول
posts
لأنه يصبح بإمكانك إضافة مقال. - بعدها يمكنك إذا شئت إدخال تعليقات في الجدول
comments
لأنه يصبح بإمكانك إضافة تعليقات.
الآن سنقوم بكتابة الأوامر التي ستنشئ لنا الجداول بالإضافة إلى تعيين المفاتيح الرئيسية و الأجنبية و ملئ الجداول ببعض القيم.
الإستعلام
بعد تنفيذ الإستعلام السابق سيتم تعبئة القيم في الجداول السبعة كالتالي.
الجدول genders
id | title |
---|---|
1 | Male |
2 | Female |
الجدول roles
id | title |
---|---|
1 | Administrator |
2 | Editor |
3 | Writer |
4 | Subscriber |
الجدول categories
id | title |
---|---|
1 | Programming |
2 | Operating Systems |
3 | Networking |
4 | Electronics |
5 | Artificial Intelligence |
الجدول users
id | username | password | first_name | last_name | birthdate | phone | gender_id | role_id | |
---|---|---|---|---|---|---|---|---|---|
1 | mhamad | pass1234 | mhamad@example.com | Mhamad | Harmush | 1994-05-12 | +96101708089 | 1 | 1 |
2 | ahmad | pass1234 | ahmad@exmaple.com | Ahmad | Masri | 1998-08-18 | +962358645235 | 1 | 2 |
3 | hala | pass1234 | hala@exmaple.com | Hala | Hassan | 1998-01-16 | +96370348927 | 2 | 4 |
4 | rola | pass1234 | rola@exmaple.com | Rola | Senjekdar | 2000-01-01 | +96325684752 | 2 | 4 |
5 | ziad | pass1234 | ziad@exmaple.com | Ziad | Asmar | 1992-05-2 | +966087046489 | 1 | 3 |
6 | mostafa | pass1234 | mostafa@exmaple.com | Mostafa | Kamel | 1988-02-12 | +97305654975 | 1 | 2 |
7 | saly | pass1234 | saly@exmaple.com | Saly | Saadi | 2001-11-17 | +94856215578 | 2 | 3 |
8 | shahad | pass1234 | shahad@exmaple.com | Shahad | Alanzy | 1995-08-08 | +985865862569 | 2 | 4 |
9 | hazem | pass1234 | hazem@exmaple.com | Hazem | Hassoun | 1997-06-17 | +964258258855 | 1 | 4 |
10 | rana | pass1234 | rana@exmaple.com | Rana | Karim | 1989-11-01 | +98215482365 | 2 | 4 |
كلمة السر pass1234
لو كنا سنشفرها بخوارزمية MD5 لكنت رأيتها في قاعدة البيانات محفوظة هكذا b4af804009cb036a4ccdc33431ef9ac9
.
في هذا الدرس لم نركز إطلاقاً على التشفير لأن هذا موضوع آخر ليس له علاقة بمبادئ قواعد البيانات بل هو أمر مرتبط بشكل أساسي بالبرمجة و الشبكات.
الجدول photos
id | url | physical_path | size_KB | user_id |
---|---|---|---|---|
1 | https://harmash.com/uploaded/photos/6546842.PNG | uploaded/photos/6546842.PNG | 1027 | 1 |
2 | https://harmash.com/uploaded/photos/5324654.PNG | uploaded/photos/5324654.PNG | 2088 | 2 |
3 | https://harmash.com/uploaded/photos/5249824.PNG | uploaded/photos/5249824.PNG | 1512 | 4 |
4 | https://harmash.com/uploaded/photos/4578515.PNG | uploaded/photos/4578515.PNG | 1065 | 5 |
5 | https://harmash.com/uploaded/photos/8789354.PNG | uploaded/photos/8789354.PNG | 2005 | 8 |
6 | https://harmash.com/uploaded/photos/5878942.PNG | uploaded/photos/5878942.PNG | 1687 | 9 |
الجدول posts
id | url | title | content | publishing_date | are_comments_enabled | user_id | category_id |
---|---|---|---|---|---|---|---|
1 | https://harmash.com/java/java-overview | Java Overview | Java is a popular programming language, created in... | 2020-03-01 | true | 5 | 1 |
2 | https://harmash.com/linux/linux-file-system | Linux File System | The Filesystem Hierarchy Standard (FHS) defines th... | 2020-03-03 | true | 1 | 2 |
الجدول comments
id | content | publishing_date | parent_comment_id | user_id | post_id |
---|---|---|---|---|---|
1 | Great introduction! | 2020-03-01 | NULL | 3 | 1 |
2 | Wow, this is very helpful. | 2020-03-02 | NULL | 4 | 1 |
3 | How to Users in Linux? | 2020-03-03 | NULL | 9 | 2 |
4 | Execute the following code: cat /etc/passwd | 2020-03-04 | 3 | 1 | 2 |
أمثلة شاملة حول استرجاع البيانات
المثال الأول
الإستعلام التالي يقوم بعرض email
الشخص الذي يعتبر مدير المدونة ( Administrator ).
الإستعلام
إذا كنت تعرف أن المدير هو الشخص الذي يملك role_id
يساوي 1
يمكنك مباشرةً كتابة التالي.
إذا أردت الإعتماد على كلمة Administrator لمعرفة الشخص الذي يعتبر المدير, يجب أن تكتب التالي.
سنحصل على النتيجة التالية عند تنفيذ الإستعلام.
mhamad@example.com |
المثال الثاني
الإستعلام التالي يقوم بعرض إسم مستخدم ( username
) كل شخص عنده مقال واحد على الأقل مع عرض عنوان ( title
) كل مقال.
لتقليل حجم الكود, قمنا بوضع الحرف u
كإسم مختصر للجدول users
, و الحرف p
كإسم مختصر للجدول posts
.
جعلنا نوع الربط JOIN للإشارة إلى أننا نريد عرض الأشخاص الذين عندهم مقالات فقط.
الإستعلام
سنحصل على النتيجة التالية عند تنفيذ الإستعلام.
username | post_title |
---|---|
ziad | Java Overview |
mhamad | Linux File System |
المثال الثالث
الإستعلام التالي يقوم بإحصاء و عرض عدد الأشخاص ( users
) على حسب أدوارهم ( roles
), أي المعلومات التالية:
- كم شخص عبارة عن Administrator.
- كم شخص عبارة عن Editor.
- كم شخص عبارة عن Writer.
- كم شخص عبارة عن Subscriber.
لتقليل حجم الكود, قمنا بوضع الحرف r
كإسم مختصر للجدول roles
, و الحرف u
كإسم مختصر للجدول users
.
لحساب عدد المستخدمين, إستخدمنا الدالة COUNT().
وضعنا إسم الجدول roles
من الناحية اليسرى و جعلنا نوع الربط LEFT JOIN للإشارة إلى أننا نريد عرض كل الأدوار حتى و لو لم يكن هناك أي شخص له دور محدد منها.
بما أن الإحصاء سيرتكز على إحصاء عدد الأدوار نسبةً لدور كل مستخدم, قمنا بتجميع الأدوار نسبة لعناوين ( title
) الأدوار.
الإستعلام
سنحصل على النتيجة التالية عند تنفيذ الإستعلام.
roles | users |
---|---|
Administrator | 1 |
Editor | 2 |
Subscriber | 5 |
Writer | 2 |
المثال الرابع
الإستعلام التالي يقوم بعرض إسم كل شخص (إسمه و إسم عائلته) في عمود واحد بالإضافة إلى جنسه و دوره في المدونة مع ترتيب النتيجة النهائية نسبةً لأدوار الأشخاص.
المعلومات التي نريدها موجودة في ثلاث جداول هي users
و genders
و roles
, لذا سنقوم بوضع أسماء مختصرة لتصغير حجم كود الإستعلام.
- الجدول
users
وضعنا الحرفu
كإسم مختصر له. - الجدول
genders
وضعنا الحرفg
كإسم مختصر له. - الجدول
roles
وضعنا الحرفr
كإسم مختصر له.
لدمج إسم الشخص مع إسم عائلته في عمود واحد سنستخدم الدالة CONCAT().
للحصول على مسمى جنس المستخدم في المدونة يجب أن نربط الحقل gender_id
الموجود في الجدول u
مع الحقل id
الموجود في الجدول g
.
للحصول على مسمى دور المستخدم في المدونة يجب أن نربط الحقل role_id
الموجود في الجدول u
مع الحقل id
الموجود في الجدول r
.
الإستعلام
سنحصل على النتيجة التالية عند تنفيذ الإستعلام.
name | gender | role |
---|---|---|
Mhamad Harmush | Male | Administrator |
Mostafa Kamel | Male | Editor |
Ahmad Masri | Male | Editor |
Hazem Hassoun | Male | Subscriber |
Rana Karim | Female | Subscriber |
Shahad Alanzy | Female | Subscriber |
Rola Senjekdar | Female | Subscriber |
Hala Hassan | Female | Subscriber |
Saly Saadi | Female | Writer |
Ziad Asmar | Male | Writer |
المثال الخامس
الإستعلام التالي يقوم بوضع إسم كل مستخدم ( username
) في الجدول users
بالإضافة إلى رابط صورته ( url
) الموضوع في الجدول photos
.
في حال كان الشخص لا يملك صورة في الجدول photos
سيتم عرض جملة No Photo
في النتيجة النهائية.
لتقليل حجم الكود, قمنا بوضع الحرف u
كإسم مختصر للجدول users
, و الحرف p
كإسم مختصر للجدول photos
.
لتبديل أي قيمة Null
في العمود photo
بالجملة No Photo
إستخدمنا الدالة IFNULL().
وضعنا إسم الجدول users
من الناحية اليسرى و جعلنا نوع الربط LEFT JOIN للإشارة إلى أننا نريد عرض كل أسماء المستخدمين حتى و لو لم يكن هناك أي صورة لهم في الجدول photos
.
الإستعلام
سنحصل على النتيجة التالية عند تنفيذ الإستعلام.
username | photo |
---|---|
mhamad | https://harmash.com/uploaded/photos/6546842.PNG |
ahmad | https://harmash.com/uploaded/photos/5324654.PNG |
hala | No Photo |
rola | https://harmash.com/uploaded/photos/5249824.PNG |
ziad | https://harmash.com/uploaded/photos/4578515.PNG |
mostafa | No Photo |
saly | No Photo |
shahad | https://harmash.com/uploaded/photos/8789354.PNG |
hazem | https://harmash.com/uploaded/photos/5878942.PNG |
rana | No Photo |
المثال السادس
الإستعلام التالي يقوم بعرض إسم مستخدم كل شخص كتب تعليق, بالإضافة إلى التعليق الذي وضعه, و عنوان المقال الذي علق عليه.
المعلومات التي نريدها موجودة في ثلاث جداول هي comments
و users
و posts
, لذا سنقوم بوضع أسماء مختصرة لتصغير حجم كود الإستعلام.
- الجدول
comments
وضعنا الحرفc
كإسم مختصر له. - الجدول
users
وضعنا الحرفu
كإسم مختصر له. - الجدول
posts
وضعنا الحرفp
كإسم مختصر له.
للحصول على إسم المستخدم الذي وضع التعليق يجب أن نربط الحقل user_id
الموجود في الجدول c
مع الحقل id
الموجود في الجدول u
.
للحصول على عنوان المقال الذي تم وضع التعليق عليه يجب أن نربط الحقل post_id
الموجود في الجدول c
مع الحقل id
الموجود في الجدول p
.
الإستعلام
سنحصل على النتيجة التالية عند تنفيذ الإستعلام.
username | comment | on_post |
---|---|---|
hala | Great introduction! | Java Overview |
rola | Wow, this is very helpful. | Java Overview |
hazem | How to Users in Linux? | Linux File System |
mhamad | Execute the following code: cat /etc/passwd | Linux File System |
المثال السابع
الإستعلام التالي يقوم بإحصاء و عرض عدد المقالات ( posts
) الموجودة في كل فئة ( categories
), أي المعلومات التالية:
- عدد المقالات التابعة لفئة Programming.
- عدد المقالات التابعة لفئة Operating Systems.
- عدد المقالات التابعة لفئة Networking.
- عدد المقالات التابعة لفئة Electronics.
- عدد المقالات التابعة لفئة Artificial Intelligence.
لتقليل حجم الكود, قمنا بوضع الحرف p
كإسم مختصر للجدول posts
, و الحرف c
كإسم مختصر للجدول categories
.
لحساب عدد المقالات, إستخدمنا الدالة COUNT().
وضعنا إسم الجدول categories
من الناحية اليسرى و جعلنا نوع الربط LEFT JOIN للإشارة إلى أننا نريد عرض كل الفئات حتى و لو لم يكن هناك أي مقال تابع لها.
بما أن الإحصاء سيرتكز على إحصاء عدد المقالات نسبةً للفئة كل مقال, قمنا بتجميع المقالات نسبة لعناوين ( title
) الفئات.
الإستعلام
سنحصل على النتيجة التالية عند تنفيذ الإستعلام.
categories | posts |
---|---|
Artificial Intelligence | 0 |
Electronics | 0 |
Networking | 0 |
Operating Systems | 1 |
Programming | 1 |
المثال الثامن
الإستعلام التالي يقوم بعرض الردود الموضوعة على التعليقات.
أي هنا نقوم بعرض محتوى ( content
) كل تعليق موضوع بمثابة رد على تعليق آخر بالإضافة إلى التعليق الذي وضع عليه الرد فقط و ليس جميع التعليقات.
بما أن التعليقات و الردود عبارة عن تعليقات عادية موضوعة في الجدول comments
مع فارق واحد هو أن التعليق يعتبر بمثابة رد في حال كان عنده parent_comment_id
يشير لتعليق آخر موجود في الجدول نفسه يجب أن نحول الجدول إلى جدولين و نربطهم بأسلوب Self Join لنتمكن من عرض التعليق و الرد الموضوع عليه.
أول نسخة من الجدول comments
قمنا بتسميتها c1
و هي التي سنحضر منها التعليق, و النسخة الثانية منه قمنا بتسميتها c2
و هي التي سنحضر منها الرد على التعليق.
الإستعلام
سنحصل على النتيجة التالية عند تنفيذ الإستعلام.
comment | reply |
---|---|
How to Users in Linux? | Execute the following code: cat /etc/passwd |