各位用户为了找寻关于mysql外键的三种关系实例详解的资料费劲了很多周折。这里教程网为您整理了关于mysql外键的三种关系实例详解的相关资料,仅供查阅,以下为您介绍关于mysql外键的三种关系实例详解的详细内容

本文实例讲述了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