您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

外键可以充当主键吗?

外键可以充当主键吗?

当然。这是一种称为超级表的常见技术。就像您的示例一样,想法是一个表包含实体的超集并具有描述通用实体的公共属性,而其他表包含具有特定属性的那些实体的子集。它与面向对象设计中的简单类层次结构没有什么不同。

对于第二个问题,一个表可以有两列,分别是指向同一张其他表的外键。数据库生成查询时,它将两次连接另一个表。为了说明一个SQL查询(不确定MysqL语法,我已经很长时间没有使用它了,所以特别是MS sql语法),在选择数据时,应为该表提供两个不同的别名。像这样:

SELECT
    student_accounts.name AS student_name,
    counselor_accounts.name AS counselor_name
FROM
    student_rec
    INNER JOIN user_accounts AS student_accounts
      ON student_rec.student_number = student_accounts.user_id
    INNER JOIN user_accounts AS counselor_accounts
      ON student_rec.guidance_counselor_id = counselor_accounts.user_id

这实际上是将student_rec表与user_accounts表进行两次组合,每列一次,并在组合它们时分配两个不同的别名,以区分它们。

其他 2022/1/1 18:21:14 有489人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶