mysql外键的三种关系实例详解

吾爱主题 阅读:170 2024-04-05 16:19:40 评论:0

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

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容