一.首先让我们来了解下什么是主外键?
1.主键:唯一标识数据表中的某一行
一般情况下,建表时先建主表,再建从表(插入数据时也是一样的),那怎么确定主从关系呢,进一步建立外键约束?
比方说,有三个表,customers表(customerid--pk) --对于 orders表和orderitems表来说是主表,反过来后两个为从表
orders表(orderid--pk;customerid--fk) --对于orderitems表来说是主表
orderitems表(orderitemid---pk;bookid,quantity,orderid---fk),
注意:一张表只能有一个主键,但可以有多个外键
从这三张表来看,orders表的customerid列为外键,它来自表customers的主键列customerid,因此这就是我们常说的外键引用主键,被引用的表为主表,引用的表为从表.即customers表为主表,orders表为从表;同样的道理下,orderitems表中的orderid列为外键,来自于(引用)表orders的主键列orderid,故针对这两个表来说,orders表为主表,而orderitems表为从表.
对于删表的顺序,刚好与建表的次序相反,先删从表再删主表,即对于上面三个表来说,先删表orderitems,再删表orders,最后才能删掉customers表.
在进行多表联接的查询操作时,我们可以以orders表作为中间表,因为他和其他两个表都有关系.即:
select * from orders a join customers c
on a.customerid=c.customerid
join orderitem t
on t.orderid=a.orderid
以上内容来自网络整理兼个人总结,感谢 http://blog.csdn.net/luoxl81/article/details/6876930 作者