0

我想创建一个使用下表返回父母及其监护人的查询。我的问题是如何使用 person 表中的 name 属性两次来返回看护者的姓名和父母的姓名。任何示例代码将不胜感激。我知道我没有很好地解释它,但是如果有人理解我的意思,请随时编辑上面的内容。更具体地说,我只想使用 person 表来存储有关父母及其子女的信息,并使用显示每个相关人员的姓名。我怎样才能用一张桌子做到这一点。

在此处输入图像描述

使用提供的一些建议,我能够创建查询,但由于我的表有问题,它不起作用。我正在使用下表:

CREATE TABLE Person
(
personID INT NOT NULL,
name VARCHAR(50),
address VARCHAR(70),
phone VARCHAR(15),
email VARCHAR(30),
year INT,
PRIMARY KEY (personID)
);

CREATE TABLE Guardian
(
parentID INT NOT NULL,
childID INT NOT NULL,
PRIMARY KEY (parentID, childID)
FOREIGN KEY (parentID) REFERENCES (personID),
FOREIGN KEY (childID) REFERENCES (personID)
);

我应该在哪里使用什么语句才能使其正常工作。我认为问题在于两个外键语句都引用了 person 表中的同一个键。在查找父项和子项时如何引用相同的属性而不会出现任何错误。

4

3 回答 3

1
SELECT
    Child.name AS ChildName,
    Parent.name AS ParentName
FROM Guardian
    INNER JOIN Person AS Child ON Child.personID = Guardian.childID
    INNER JOIN Person AS Parent ON Parent.personID = Guardian.parentID

这将为每个父/子对返回一行。

重要的特性是两次引用 Person 表,但在每种情况下都给它一个不同的别名。然后,您可以以两个不同的角色引用该表。输出列也可以使用别名来区分连接表的两个实例中的同一列。

于 2012-05-24T09:04:37.527 回答
0

你没有提到,但假设一个人只能有一个监护人,我认为你不需要两张桌子。

只需在映射到自身的 Person 表上添加一个 GuardianID。所以你会有这样的东西

Person
ID   name        GuardianID
1    The Father     null
2    The Son         1

因此,如果您想了解一个人及其监护人,您可以

select *, (select p2.name from person wherep2.id=p.guardianid)
from person p
where p.id=2
于 2012-05-24T09:03:06.203 回答
0

首先修复您的创建表:

CREATE TABLE Guardian
(
parentID INT NOT NULL,
childID INT NOT NULL,
PRIMARY KEY (parentID, childID),
FOREIGN KEY (parentID) REFERENCES Person(personID),
FOREIGN KEY (childID) REFERENCES Person(personID)
);

然后查询:

SELECT
  p.name as parentName,
  c.name as childName,
  Guardian.*
FROM Person AS p
  INNER JOIN Guardian ON p.PersonID=Guardian.parentID
  INNER JOIN Person AS c ON c.PersonID=Guardian.childID
WHERE
  -- whatever you want, e.g.
  p.Name='John'
于 2012-05-24T09:03:42.887 回答