我想知道如何创建即使外键为 NULL也可以工作的视图。例如,我们有一个表Person,它有一个主键和两个外键:
- 身份
- 名称
- Fk姓
两个外键都可以是 NULL。现在我们还有两个表,表名:
- 姓名
- 姓名
和表姓:
- 身份证号
- 姓
现在我们创建视图来显示每个人的姓名:
CREATE VIEW `Database`.`ViewPerson` AS
SELECT `N`.`Name`, `S`.`Surname`
FROM `Person` `P`, `Name` `N`, `Surname` `S`
WHERE (`P`.`FkName` = `N`.`IdName`) AND (`P`.`FkSurname` = `S`.`IdSurname`)
问题是,如果外键 FkSurname 为 NULL,那么即使定义了 FkName,也不会显示该行。我希望即使两个外键都是 NULL,它仍然返回两列都为 NULL 的行。现在我知道我可以通过添加表名称和表姓氏行来解决它,在名称/姓氏下具有 NULL ,然后在 FkName 和 FkSurname 中引用在这两列下具有 NULL 值的行。但我仍然想知道是否有外键为 NULL 并返回行的解决方案。