"إذا أراد العامل أن يؤدي عمله بشكل جيد، فعليه أولاً أن يشحذ أدواته." - كونفوشيوس، "مختارات كونفوشيوس. لو لينجونج"
الصفحة الأمامية > برمجة > هل يمكن للمفتاح الخارجي مرجع مفاتيح أولية متعددة في وقت واحد؟

هل يمكن للمفتاح الخارجي مرجع مفاتيح أولية متعددة في وقت واحد؟

نشر في 2025-03-22
تصفح:558

Can a Foreign Key Reference Multiple Primary Keys Simultaneously?

التعامل مع العلاقات الرئيسية المعقدة في تصميم قاعدة البيانات

سيناريو

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

يحمل الحل المقترح نموذج ميراث جيد التنظيم لحل هذا.

النهج القائم على الميراث الجداول للموظفين ، الموظفين _ce ، و

الموظفون

هو الجدول الأساسي ، مع

الموظفين _ce

و

كجداول متخصصة ترث منها. بنية قاعدة البيانات: الموظفين (معرف int الأساسي المفتاح ، اسم varchar (255)) الموظفين (int int inct key ، ce_specific_attribute varchar (255) ، efferene_id int ، key forefore (experiee_id) المراجعون (المعرف)) الموظفين _SN (المعرف int الأساسي المفتاح ، sn_specific_attribute varchar (255) ، efferene_id int ، المفتاح الأجنبي (الموظف_) مراجع الموظفين (معرف)) حل:

بدلاً من الرابط المباشر لكل من amploy_ce و

الموظفين _sn
employees (id INT PRIMARY KEY, name VARCHAR(255))
employees_ce (id INT PRIMARY KEY, ce_specific_attribute VARCHAR(255), employee_id INT, FOREIGN KEY (employee_id) REFERENCES employees(id))
employees_sn (id INT PRIMARY KEY, sn_specific_attribute VARCHAR(255), employee_id INT, FOREIGN KEY (employee_id) REFERENCES employees(id))
الخصومات (معرف int الأساسي المفتاح ، الموظف int ، pultuction_amount decimal (10،2) ، ... ، المفتاح الأجنبي (exepmite_id) المراجع الموظفين (معرف))

يضمن هذا النهج النزاهة المرجعية ويتجنب التكرار. يربط

effecte_id

في الخصومات إلى سجل الموظف في الموظفين ، بغض النظر عما إذا كان لدى هذا الموظف معلومات إضافية في amploy_ce أو . يدير هذا التصميم بكفاءة العلاقة ويحافظ على اتساق البيانات.

أحدث البرنامج التعليمي أكثر>

تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.

Copyright© 2022 湘ICP备2022001581号-3