我目前正在为我们团队的项目设计数据库结构。我目前在脑海中有一个非常疑问的问题:能否将外键用作另一个表上的主键?
以下是我们系统的数据库设计表:
user_accounts students guidance_counselors
我想做的是,该user_accounts表应包含学生用户和指导顾问用户的ID(应该是系统的登录凭据)和密码。简而言之,students和guidance_counselors表的主键也是表的外键user_accounts。但我不确定是否允许。
user_accounts
students
guidance_counselors
另一个问题是:一个student_rec表中也存在,这需要一个student_number(其为user_id中user_accounts表)和一个guidance_counsellor_id(这也是user_id在user_accounts)它的每个记录的。如果学生和辅导员的ID都来自user_accounts table,我将如何设计student_rec表格?为了将来参考,我如何手动将其编写为SQL代码?
student_rec
student_number
user_id
guidance_counsellor_id
user_accounts table
这一直困扰着我,我找不到任何具体或确定的答案。
当然。这是一种称为超级表的常见技术。就像您的示例一样,想法是一个表包含实体的超集并具有描述通用实体的公共属性,而其他表包含具有特定属性的那些实体的子集。它与面向对象设计中的简单类层次结构没有什么不同。
对于第二个问题,一个表可以有两列,分别是指向同一张其他表的外键。数据库生成查询时,它将两次连接另一个表。为了说明一个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表进行两次组合,每列一次,并在组合它们时分配两个不同的别名,以区分它们。