当前位置: 首页 > 面试题库 >

外键可以充当主键吗?

西门淮晨
2023-03-14
问题内容

我目前正在为我们团队的项目设计数据库结构。我目前在脑海中有一个非常疑问的问题:能否将外键用作另一个表上的主键?

以下是我们系统的数据库设计表:

user_accounts
students
guidance_counselors

我想做的是,该user_accounts表应包含学生用户和指导顾问用户的ID(应该是系统的登录凭据)和密码。简而言之,studentsguidance_counselors表的主键也是表的外键user_accounts。但我不确定是否允许。

另一个问题是:一个student_rec表中也存在,这需要一个student_number(其为user_iduser_accounts表)和一个guidance_counsellor_id(这也是user_iduser_accounts)它的每个记录的。如果学生和辅导员的ID都来自user_accounts table,我将如何设计student_rec表格?为了将来参考,我如何手动将其编写为SQL代码?

这一直困扰着我,我找不到任何具体或确定的答案。


问题答案:

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

对于第二个问题,一个表可以有两列,分别是指向同一张其他表的外键。数据库生成查询时,它将两次连接另一个表。为了说明一个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表进行两次组合,每列一次,并在组合它们时分配两个不同的别名,以区分它们。



 类似资料:
  • 我有两张桌子: 用户(用户名、密码) 配置文件(profileId,gender,dateofbirding,...) 目前我正在使用这种方法:每个Profile记录都有一个名为“userid”的字段作为外键,它链接到用户表。当用户注册时,他的配置文件记录将自动创建。 我对我朋友的建议感到困惑:将“userid”字段作为外部和主键,并删除“profileid”字段。哪种方法更好?

  • 问题内容: 如果不需要主键,是否不应该将主键添加到数据库中? 问题答案: 主键唯一地标识表中的一行。 它被索引和/或群集的事实是一个物理实现问题,与逻辑设计无关。 您需要一张桌子才能使它有意义。

  • 我有一个包含数据的表,其中一个行需要存在于另一个表中。所以,我想要一个外键来保持引用的完整性。 但是,正如您所看到的,我的外键所指向的表,列不是PK。有没有一种方法来创建这个外键,或者可能有一种更好的方法来维护这个引用完整性?

  • 我是SQL新手,正在尝试创建一个如下的模式。然而,我似乎不能正确获得成员表的外键。我试着在表创建后添加它,最初似乎工作正常,但现在当我试图添加一个测试数据行时,我得到了这个错误。 我敢肯定,这是我错过的非常愚蠢的事情,但如果有人能指出我做错了什么,那就太好了! 错误代码:1452。无法添加或更新子行:外键约束失败 (。,CONSTRAINTFOREIGN KEY()REFERENCES()) 无法

  • 一开始我尝试过,如下所示,但仍然没有结果: 将两个外键定义为实体框架中的主键 实体框架两个外键作为主键 这是我的实体: 我正在尝试基于两个外键创建主键。有一个错误 EntityType“Passage”未定义键。定义此EntityType的键。 我做错了什么?

  • 如何使用hibernate注释实现下表? 当前代码为:(为简洁起见,已删除) 使用者 社交网络 SocialProfile公司 显然我的代码现在不能正常工作。有人能解释一下吗?