首页 > 数据库 > mysql教程 > 外键可以引用不同表中的多个主键吗?最好的选择是什么?

外键可以引用不同表中的多个主键吗?最好的选择是什么?

DDD
发布: 2025-01-11 08:16:41
原创
275 人浏览过

Can a Foreign Key Reference Multiple Primary Keys in Different Tables, and What's the Best Alternative?

跨表外键引用

本文探讨在一个表中创建外键以引用多个其他表的主键的可能性。具体来说,它围绕提问者提出的场景展开。

场景解读

提问者有两个表,employees_ceemployees_sn,每个表都有自己的主键列。他们还有一个名为 deductions 的第三个表,需要一个外键来引用 employees_ceemployees_sn 的主键。提供的示例进一步说明了这种情况:

<code>employees_ce
--------------
empid   name
khce1   prince

employees_sn
----------------
empid   name
khsn1   princess</code>
登录后复制
<code>deductions
--------------
id      name
khce1   gold
khsn1   silver</code>
登录后复制
登录后复制

解决方案

虽然提问者的目标在技术上是可以实现的,但这并非数据库设计的最佳实践。推荐的方法是定义一个中间表来链接这两个表,例如:

<code>employees
----------------
empid   name

employees_types
---------------
empid   type
khce1   ce
khsn1   sn</code>
登录后复制

通过这种设置,deductions 表可以有一个外键引用 employees 表中的 empid 列,从而在三个表之间建立简单的关系。

<code>deductions
--------------
id      name
khce1   gold
khsn1   silver</code>
登录后复制
登录后复制

中间表方法的优势

中间表方法提供以下几个优点:

  • 它通过提供单个引用点来引用员工,简化了数据管理。
  • 它避免了外键引用多个主键的问题,这可能会导致不一致和数据完整性问题。
  • 它允许灵活性和可扩展性,能够添加其他员工类型而无需更改 deductions 表。

以上是外键可以引用不同表中的多个主键吗?最好的选择是什么?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板