SQL数据操作基础(初级)2(二)

2014-11-24 10:11:22 · 作者: · 浏览: 1
r.au_id 的字段属于表authors,名为titleauthor.au_id的字段属于表titleauthor,两者不会混
淆。

通过使用第三个表,你可以在两个表的字段之间建立各种类型的关系。例如,一个作者也许写了许多不同的书,或者一本书也许由
许多不同的作者共同完成。当两个表的字段之间有这种“多对多”的关系时,你需要使用第三个表来指明这种关系。

但是,在许多情况下,两个表之间的关系并不复杂。比如你需要指明表titles和表publishers之间的关系。因为一个书名不可能与
多个出版商相匹配,你不需要通过第三个表来指明这两个表之间的关系。要指明表titles和表publishers之间的关系,你只要让这
两个表有一个公共的字段就可以了。在数据库pubs中,表titles和表publishers都有一个名为pub_id的字段。如果你想得到书名
及其出版商的一个列表,你可以使用如下的语句:

SELECT title,pub_name FROM titles,publishers

WHERE titles.pub_id=publishers.pub_id

当然,如果一本书是由两个出版商联合出版的,那么你需要第三个表来代表这种关系。

通常,当你予先知道两个表的字段间存在“多对多”关系时,就使用第三个表来关联这两个表。反之,如果两个表的字段间只有“一对一”或“一对多”关系,你可以使用公共字段来关联它门。