数据库——表之间的关系

本文探讨了数据库中表之间的三种主要关系:一对多、多对多和一对一。在一对多关系中,一个出版社可以出版多本书,通过foreign key实现。多对多关系下,一个作者可以写多本书,一本书也可有多个作者,这需要通过foreign key加上额外的关联表来实现。而一对一关系中,通过在左表的外键字段上设置unique约束,确保左表的一条记录唯一对应右表的一条记录。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 一对多(或多对一):一个出版社可以出版多本书

    关联方式:foreign key

  • 多对多:一个作者可以写多本书,一本书也可以有多个作者,即多对多。先建立完成插入记录完成两个表之后,再建立关系,然后插入记录。

    关联方式:foreign key+一张新的表

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)
);

  • 一对一
    左表的一条记录唯一对应右表的一条记录
    在左表foreign key右表的基础上,将左表的外键字段设置成unique即可

    关联方式:foreign key + unique

#学生一定是一个客户,
#客户不一定是学生,但有可能成
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值