SQL 数据库 学习 011 关系、一对一、一对多、多对多

SQL数据库关系详解:一对一、一对多、多对多
本文介绍了SQL数据库中关系的概念,包括一对一、一对多和多对多三种关系,并详细阐述了它们的实现方式。重点讨论了一对多和多对多关系的实现,通过实例解释了如何在SQL Server中设置这些关系。

  • 我的电脑系统:Windows 10 64位
  • SQL Server 软件版本: SQL Server 2014 Express

什么是关系

定义:

  • 表和表之间的联系。

实现方式:

  • 通过设置不同形式的外键来体现表和表的不同关系。

关系的分类(假设是A表和B表)

第一种分类: 一对一 (详述一对一关系及其实现)

(一对一,几乎不使用。所以,我们就一句话带过。)

一对一的实现:既可以把表A的主键充当表B的外键,也可以把表B的主键充当表A的外键。

一对多 和 多对多 才是我们学习的重点。

第二种分类:一对多 (详述一对多关系及其实现)

一对多事怎么实现的?

表A(一)与表B(多)(我们现在希望,表A中的一条记录对应表B中的多条记录)之间要是有关系,就必须要有外键。把表A的主键添加到表B里面,充当表B的外键。

一对多的实现:在多的一方的表里面,添加外键。

第三种分类:多对多 (详述多对多关系及其实现)

现实中,什么事物和什么事物之间是多对多的关系?

班级和老师的关系。(一个班级有很多老师上课,一个老师可以去很多班级上课。)

多对多其实就是:一对多 和 多对一 的一个组合。

多对多的实现:多对多 必须要通过单独的一张表来表示。

  • 班级是一张表
  • 教师是一张表
  • 班级和教师的关系也是一张表

用一个实例来解释 多对多。

--班级表
create table banji
(
    banji_id int primary key,
    banji_num int not null,
    banji_name nvarchar(100)
)

--教师
create table jiaoshi
(
    jiaoshi_id int primary key,
    jiaoshi_name nvarchar(200)
)

--第三张表:用来模拟班级和教师的关系
create table banji_jiaoshi_mapping
(
    banji_id int constraint fk_banji_id foreign key references banji(bianji_id),
    jiaoshi_id int foreign key references jiaoshi(jiaoshi_id),
    kecheng nvarchar(20),
    constraint pk_banji_id_jiaoshi_id primary key (banji_id, jiaoshi_id, kecheng)

)

解释代码:

其中banji_id int constraint fk_banji_id foreign key references banji(bianji_id), 代码中的 fk_banji_id 是约束的名字,foreign key references banji(bianji_id) 指的是:当前这个表里面的 banji_id 属性是来自 banji 表的主键 banji_id,也就是说:当前表中的 banji_id 是一个外键(foreign key)。

其中jiaoshi_id int foreign key references jiaoshi(jiaoshi_id),里面,这里没有命名约束的名字,约束的名字可以省略不写,所以这里没有写也没有问题。同理上面那句代码。

其中constraint pk_banji_id_jiaoshi_id primary key (banji_id, jiaoshi_id, kecheng)中的 pk_banji_id_jiaoshi_id 这个是约束的名字。primary key (banji_id, jiaoshi_id, kecheng) 是设置jiaoshi_idbanji_idkecheng 三个属性的组合是一个主键primary key)。

现在执行,生成了3个表。

现在我们在这3个表里面插入数据。

banji

Alt text

jiaoshi

Alt text

banji_jiaoshi_mapping

Alt text

都不会有错误,说明多对多生成成功。


请访问:http://www.aobosir.com/

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值