本文实例讲述了mysql外键的三种关系。分享给大家供大家参考,具体如下:
因为有foreign key的约束,使得两张表形成了三种了关系:
- 多对一
- 多对多
- 一对一
一对多或多对一
多对一
1
2
3
4
5
6
7
8
9
10
11
12
|
create table press( id int primary key auto_increment, name varchar (20) ); create table book( id int primary key auto_increment, name varchar (20), press_id int not null , constraint fk_book_press foreign key (press_id) references press(id) on delete cascade on update cascade ); |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
# 先往被关联表中插入记录 insert into press( name ) values ( '北京工业地雷出版社' ), ( '人民音乐不好听出版社' ), ( '知识产权没有用出版社' ) ; # 再往关联表中插入记录 insert into book( name ,press_id) values ( '九阳神功' ,1), ( '九阴真经' ,2), ( '九阴白骨爪' ,2), ( '独孤九剑' ,3), ( '降龙十巴掌' ,2), ( '葵花宝典' ,3) ; |
查询结果:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
mysql> select * from book; + ----+-----------------+----------+ | id | name | press_id | + ----+-----------------+----------+ | 1 | 九阳神功 | 1 | | 2 | 九阴真经 | 2 | | 3 | 九阴白骨爪 | 2 | | 4 | 独孤九剑 | 3 | | 5 | 降龙十巴掌 | 2 | | 6 | 葵花宝典 | 3 | + ----+-----------------+----------+ rows in set (0.00 sec) mysql> select * from press; + ----+--------------------------------+ | id | name | + ----+--------------------------------+ | 1 | 北京工业地雷出版社 | | 2 | 人民音乐不好听出版社 | | 3 | 知识产权没有用出版社 | + ----+--------------------------------+ rows in set (0.00 sec) |
多对多,引入第三张表
多对多
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
# 创建被关联表author表,之前的book表在讲多对一的关系已创建 create table author( id int primary key auto_increment, name varchar (20) ); #这张表就存放了author表和book表的关系,即查询二者的关系查这表就可以了 create table author2book( id int not null unique auto_increment, author_id int not null , book_id int not null , constraint fk_author foreign key (author_id) references author(id) on delete cascade on update cascade , constraint fk_book foreign key (book_id) references book(id) on delete cascade on update cascade , primary key (author_id,book_id) ); #插入四个作者,id依次排开 insert into author( name ) values ( 'egon' ),( 'alex' ),( 'wusir' ),( 'yuanhao' ); # 每个作者的代表作 egon: 九阳神功、九阴真经、九阴白骨爪、独孤九剑、降龙十巴掌、葵花宝典 alex: 九阳神功、葵花宝典 wusir:独孤九剑、降龙十巴掌、葵花宝典 yuanhao:九阳神功 # 在author2book表中插入相应的数据 insert into author2book(author_id,book_id) values (1,1), (1,2), (1,3), (1,4), (1,5), (1,6), (2,1), (2,6), (3,4), (3,5), (3,6), (4,1) ; |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
# 现在就可以查author2book对应的作者和书的关系了 mysql> select * from author2book; + ----+-----------+---------+ | id | author_id | book_id | + ----+-----------+---------+ | 1 | 1 | 1 | | 2 | 1 | 2 | | 3 | 1 | 3 | | 4 | 1 | 4 | | 5 | 1 | 5 | | 6 | 1 | 6 | | 7 | 2 | 1 | | 8 | 2 | 6 | | 9 | 3 | 4 | | 10 | 3 | 5 | | 11 | 3 | 6 | | 12 | 4 | 1 | + ----+-----------+---------+ rows in set (0.00 sec) |
一对一的情况
一对一
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
#例如: 一个用户只能注册一个博客 #两张表: 用户表 ( user )和 博客表(blog) # 创建用户表 create table user ( id int primary key auto_increment, name varchar (20) ); # 创建博客表 create table blog( id int primary key auto_increment, url varchar (100), user_id int unique , constraint fk_user foreign key (user_id) references user (id) on delete cascade on update cascade ); #插入用户表中的记录 insert into user ( name ) values ( 'alex' ), ( 'wusir' ), ( 'egon' ), ( 'xiaoma' ) ; # 插入博客表的记录 insert into blog(url,user_id) values ( 'http://www.cnblog/alex' ,1), ( 'http://www.cnblog/wusir' ,2), ( 'http://www.cnblog/egon' ,3), ( 'http://www.cnblog/xiaoma' ,4) ; # 查询wusir的博客地址 select url from blog where user_id=2; |
希望本文所述对大家MySQL数据库计有所帮助。
原文链接:https://www.cnblogs.com/mmyy-blog/p/9626840.html