表1 foreign key 表2
则表1的多条记录对应表2的一条记录,即多对一
利用foreign key的原理我们可以制作两张表的多对多,一对一关系
多对多:
表1的多条记录可以对应表2的一条记录
表2的多条记录也可以对应表1的一条记录
一对一:
表1的一条记录唯一对应表2的一条记录,反之亦然
分析时,我们先从按照上面的基本原理去套,然后再翻译成真实的意义,就很好理解了
1、先确立关系
2、找到多的一方,吧关联字段写在多的一方
一、多对一或者一对多(左边表的多条记录对应右边表的唯一一条记录)
需要注意的:1.先建被关联的表,保证被关联表的字段必须唯一。
2.在创建关联表,关联字段一定保证是要有重复的。
其实上一篇博客已经举了一个多对一关系的小例子了,那我们在用另一个小例子来回顾一下。
这是一个书和出版社的一个例子,书要关联出版社(多个书可以是一个出版社,一个出版社也可以有好多书)。
谁关联谁就是谁要按照谁的标准。
书要关联出版社
被关联的表
create table press(
id int primary key auto_increment,
name char(20)
);
关联的表
create table book(
book_id int primary key auto_increment,
book_name varchar(20),
book_price int,
press_id int,
constraint Fk_pressid_id foreign key(press_id) references press(id)
on delete cascade
on update cascade
);
插记录
insert into press(name) values('新华出版社'),
('海燕出版社'),
('摆渡出版社'),
('大众出版社');
insert into book(book_name,book_price,press_id) values('Python爬虫',100,1),
('Linux',80,1),
('操作系统',70,2),
('数学',50,2),
('英语',103,3),
('网页设计',22,3);
运行结果截图:
二、一对一
例子一:用户和管理员(只有管理员才可以登录,一个管理员对应一个用户)
管理员关联用户