JOIN Clause

From binaryoption
Jump to navigation Jump to search
Баннер1

```wiki

جملة الربط (JOIN Clause) في SQL للمبتدئين

جملة الربط (JOIN) في لغة SQL هي أداة قوية تسمح لك بدمج الصفوف من جدولين أو أكثر بناءً على علاقة ذات صلة بينهما. هذه العلاقة عادةً ما تكون موجودة في عمود واحد أو أكثر مشترك بين الجداول. فهم جملة الربط أمر بالغ الأهمية لاسترجاع البيانات المعقدة وتحليلها من قواعد البيانات العلائقية. هذا المقال مصمم للمبتدئين ويهدف إلى شرح مفهوم الربط بالتفصيل، مع أمثلة عملية ونصائح مفيدة.

ما هي قواعد البيانات العلائقية؟

قبل الغوص في تفاصيل الربط، من المهم فهم أساسيات قواعد البيانات العلائقية. في قاعدة البيانات العلائقية، يتم تنظيم البيانات في جداول. كل جدول يتكون من صفوف (Records) وأعمدة (Fields). تنشأ العلاقة بين الجداول عندما يكون لدى جدولين أو أكثر عموداً واحداً أو أكثر يحمل نفس نوع البيانات ويمثل نفس الكيان. على سبيل المثال، قد يكون لديك جدول "العملاء" وجدول "الطلبات"، وكلاهما يحتوي على عمود "معرف_العميل" الذي يربط بينهما.

لماذا نستخدم جملة الربط؟

بدون جملة الربط، سيكون من الصعب للغاية استرجاع البيانات المرتبطة من جداول متعددة. على سبيل المثال، إذا كنت ترغب في معرفة جميع الطلبات التي قدمها عميل معين، فسيتعين عليك تنفيذ استعلامين منفصلين:

1. استعلام لاسترجاع معلومات العميل بناءً على معرّف العميل. 2. استعلام لاسترجاع جميع الطلبات التي تحتوي على معرّف العميل المطابق.

جملة الربط تسمح لك بتنفيذ هذه العملية في استعلام واحد، مما يجعل الكود أكثر كفاءة وقراءة.

أنواع جملة الربط

هناك عدة أنواع من جمل الربط، ولكل منها سلوك مختلف. أكثر أنواع الربط شيوعًا هي:

  • INNER JOIN: يُرجع فقط الصفوف التي لها تطابق في كلا الجدولين.
  • LEFT (OUTER) JOIN: يُرجع جميع الصفوف من الجدول الأيسر (الجدول المذكور أولاً في جملة الربط) وصفوفًا متطابقة من الجدول الأيمن. إذا لم يكن هناك تطابق في الجدول الأيمن، فسيتم إرجاع قيم NULL للأعمدة من الجدول الأيمن.
  • RIGHT (OUTER) JOIN: يُرجع جميع الصفوف من الجدول الأيمن وصفوفًا متطابقة من الجدول الأيسر. إذا لم يكن هناك تطابق في الجدول الأيسر، فسيتم إرجاع قيم NULL للأعمدة من الجدول الأيسر.
  • FULL (OUTER) JOIN: يُرجع جميع الصفوف من كلا الجدولين. إذا لم يكن هناك تطابق في أحد الجدولين، فسيتم إرجاع قيم NULL للأعمدة من الجدول الآخر.
  • CROSS JOIN: يُرجع حاصل الضرب الديكارتي لجميع الصفوف في كلا الجدولين. هذا يعني أنه لكل صف في الجدول الأول، سيتم إرجاع صف لكل صف في الجدول الثاني.

شرح مفصل مع أمثلة

لنفترض أن لدينا جدولين: "العملاء" و "الطلبات"

جدول العملاء
الاسم | المدينة | أحمد | الرياض | فاطمة | جدة | خالد | الدمام | سارة | مكة |
جدول الطلبات
معرف_العميل | المنتج | الكمية | 1 | هاتف | 2 | 2 | لابتوب | 1 | 1 | شاشة | 1 | 3 | لوحة مفاتيح | 3 | 5 | فأرة | 2 |

INNER JOIN

```sql SELECT العملاء.الاسم, الطلبات.المنتج FROM العملاء INNER JOIN الطلبات ON العملاء.معرف_العميل = الطلبات.معرف_العميل; ```

هذا الاستعلام سيُرجع فقط الصفوف التي يوجد فيها تطابق بين "معرف_العميل" في كلا الجدولين. النتيجة ستكون:

نتيجة INNER JOIN
المنتج | هاتف | لابتوب | شاشة | لوحة مفاتيح |

LEFT JOIN

```sql SELECT العملاء.الاسم, الطلبات.المنتج FROM العملاء LEFT JOIN الطلبات ON العملاء.معرف_العميل = الطلبات.معرف_العميل; ```

هذا الاستعلام سيُرجع جميع الصفوف من جدول "العملاء" وصفوفًا متطابقة من جدول "الطلبات". لاحظ أن العميل "سارة" (معرف_العميل = 4) ليس لديه أي طلبات، لذلك سيكون عمود "المنتج" الخاص بها NULL. النتيجة ستكون:

نتيجة LEFT JOIN
المنتج | هاتف | لابتوب | لوحة مفاتيح | NULL | شاشة |

RIGHT JOIN

```sql SELECT العملاء.الاسم, الطلبات.المنتج FROM العملاء RIGHT JOIN الطلبات ON العملاء.معرف_العميل = الطلبات.معرف_العميل; ```

هذا الاستعلام سيُرجع جميع الصفوف من جدول "الطلبات" وصفوفًا متطابقة من جدول "العملاء". لاحظ أن الطلب رقم 105 (معرف_العميل = 5) لا يوجد له عميل مطابق في جدول "العملاء"، لذلك سيكون عمود "الاسم" الخاص به NULL.

FULL JOIN

FULL JOIN غير مدعوم مباشرة في جميع أنظمة قواعد البيانات (مثل MySQL). يمكن محاكاته باستخدام UNION ALL و LEFT JOIN و RIGHT JOIN.

CROSS JOIN

```sql SELECT العملاء.الاسم, الطلبات.المنتج FROM العملاء CROSS JOIN الطلبات; ```

هذا الاستعلام سيُرجع حاصل الضرب الديكارتي لجميع الصفوف في كلا الجدولين. ستكون النتيجة كبيرة جدًا، حيث سيتم دمج كل عميل مع كل طلب.

شروط الربط (JOIN Conditions)

شرط الربط (ON clause) هو الجزء الأكثر أهمية في جملة الربط. يحدد العلاقة بين الجداول. يجب أن يكون شرط الربط يعتمد على عمود واحد أو أكثر مشترك بين الجداول. استخدام شروط الربط غير الصحيحة يمكن أن يؤدي إلى نتائج غير صحيحة أو غير متوقعة.

استخدام الأسماء المستعارة (Aliases)

يمكنك استخدام الأسماء المستعارة لتبسيط جملة الربط وجعلها أكثر قابلية للقراءة. على سبيل المثال:

```sql SELECT c.الاسم, o.المنتج FROM العملاء AS c INNER JOIN الطلبات AS o ON c.معرف_العميل = o.معرف_العميل; ```

في هذا المثال، استخدمنا الاسم المستعار "c" لجدول "العملاء" والاسم المستعار "o" لجدول "الطلبات".

الربط المتعدد (Multiple Joins)

يمكنك ربط أكثر من جدولين في استعلام واحد. على سبيل المثال، إذا كان لديك جدول "الموردين" وترغب في استرجاع معلومات حول الموردين والطلبات والعملاء، يمكنك استخدام جملة ربط متعددة:

```sql SELECT c.الاسم, o.المنتج, s.اسم_المورد FROM العملاء AS c INNER JOIN الطلبات AS o ON c.معرف_العميل = o.معرف_العميل INNER JOIN الموردين AS s ON o.معرف_المورد = s.معرف_المورد; ```

اعتبارات الأداء

يمكن أن تكون جمل الربط مكلفة من حيث الأداء، خاصةً إذا كانت الجداول كبيرة. لتحسين الأداء، تأكد من:

  • استخدام الفهارس (Indexes) على الأعمدة المستخدمة في شروط الربط.
  • كتابة شروط الربط بكفاءة.
  • تجنب استخدام CROSS JOIN إلا إذا كان ذلك ضروريًا للغاية.
  • استخدام الأسماء المستعارة لتقليل حجم الاستعلام.

الربط في سياق الخيارات الثنائية

على الرغم من أن الربط هو مفهوم SQL، إلا أنه يمكن أن يكون له تطبيقات غير مباشرة في تحليل بيانات الخيارات الثنائية. على سبيل المثال، يمكن استخدام جملة الربط لدمج بيانات من مصادر مختلفة، مثل بيانات الأسعار التاريخية، وبيانات حجم التداول، وبيانات المؤشرات الفنية. هذا يمكن أن يساعد المتداولين في تحديد فرص التداول المحتملة.

الخلاصة

جملة الربط هي أداة أساسية في SQL تسمح لك بدمج البيانات من جداول متعددة. فهم أنواع الربط المختلفة وكيفية استخدامها بشكل صحيح أمر بالغ الأهمية لاسترجاع البيانات المعقدة وتحليلها. من خلال التدريب والممارسة، يمكنك إتقان جملة الربط واستخدامها لتحسين كفاءة ودقة استعلامات SQL الخاصة بك. تذكر دائماً أهمية شروط الربط الصحيحة واعتبارات الأداء.

SQL Structured Query Language قاعدة بيانات جدول (قاعدة بيانات) صف (قاعدة بيانات) عمود (قاعدة بيانات) استعلام SQL الفهرس (قاعدة بيانات) اسم مستعار (SQL) تحليل البيانات تحليل حجم التداول المؤشرات الفنية الخيارات الثنائية ```

ابدأ التداول الآن

سجّل في IQ Option (الحد الأدنى للإيداع 10 دولار) افتح حساباً في Pocket Option (الحد الأدنى للإيداع 5 دولار)

انضم إلى مجتمعنا

اشترك في قناة Telegram الخاصة بنا @strategybin لتصلك: ✓ إشارات تداول يومية ✓ تحليلات استراتيجية حصرية ✓ تنبيهات اتجاهات السوق ✓ مواد تعليمية للمبتدئين

Баннер