MySql的复合主键和联合主键的介绍

我的个人博客

百度搜索:【迷你酷吧】网址:https://www.minikuba.com,迷你酷吧是一个基于程序员经验为基础分享技术文章、算法解题、大厂面试真题、热门项目的平台,致力于为大家提供更多涵盖前后端技术、技能的学习,助力广大热衷编程开发者全面发展。本文章链接https://www.minikuba.com/article/126

复合主键

CREATE  TABLE stu_detail(
id INT NOT NULL AUTO_INCREMENT,
age INT COMMENT '学生年龄',
address VARCHAR(50) COMMENT '学生住址',
phone CHAR(11) NOT NULL COMMENT '学生号码',
cid INT NOT NULL,
PRIMARY KEY (id,address)
);

复合主键是指数据库表的主键含有一个以上的字段组成。例如上面的表就是创建了复合主键,表中的id和name字段组合起来就是表course的复合主键,为什么会出现复合主键,这是因为表name字段可能出现重名的情况,所以要加上id字段来保证记录的唯一性,而我们在开发中,主键字段数是保持一个是比较好的,非要创建两个复合主键,那么在创建表的时候就应该寻找一个能唯一性标识该对象的一个字段来识别。
那么问题又来了,不是说一个表只能有一个主键吗?主键是一个表的唯一索引啊,那么为何一个表可以创建多个主键呢?
其实“主键是唯一的索引”这话有点歧义的,举个例子说明:我们习惯性的在表中都会有一个id字段,设置为自动增长,并设置为主键,这时候"主键是唯一的索引",id自动增长保证来唯一性。此时,在创建一个字段name varchar(50),也被设置为了主键,这时候id和name就成为了复合主键了,而表中的name字段在插入数据时是可以插入相同的name值的,这时候又有问题了,不是说"主键是唯一索引吗?怎么能有相同的值?"
所以说"主键是唯一性索引"是有歧义的;主键是唯一性索引的前提是"当表中只有一个主键时,它才是唯一的索引;当表中有多个主键时,称为复合主键,复合主键联合保证唯一性索引,即可理解为复合主键联合起来成为了一个表的唯一性索引(主键)"。为什么自增长ID已经可以作为唯一标识的主键,为啥还需要复合主键呢?因为,并不是所有的表都要有id这个字段啊,比如,我们建一个学生表,没有唯一能标识学生的ID,怎么办呢?学生的名字、年龄、班级都可能重复,无法使用单个字段来唯一标识,这时,我们可以将多个字段设置为主键,形成复合主键,这多个字段联合标识唯一性,其中,某几个主键字段值出现重复是没有问题的,只要不是有多条记录的所有主键值完全一样,就不算重复。

总结: 在开发中,主键字段数最好保持一个,非要创建两个复合主键,那么在创建表的时候就应该要寻找一个能唯一性标识该对象的一个字段来识别。简而言之就是少用复合主键。

联合主键

联合主键和复合主键的区别在于:联合主键体现在多个表上,复合主键体现在一个表中的多个字段。

学生表:student
create table student(
id int auto_increment comment '主键id',
name varchar(30) comment '姓名',
age smallint comment '年龄',
primary key(id)
);

课程表:course
create table course(
id int auto_increment comment '主键id',
name varchar(30) comment '课程名称',
primary key(id)
);

学生课程表:stu_course
create table IF NOT EXISTS stu_cour(
id int  auto_increment comment '主键id',
stu_id mediumint comment '学生表id',
cour_id mediumint comment '课程表id',
primary key(id)
);

此时stu_course中id就表示联合主键,通过id可以获取学生和课程的一条记录

所以联合主键,顾名思义就是多个主键联合形成一个主键组合,体现在联合。 (主键原则上是唯一的,别被唯一值所困扰) 索引可以极大的提高数据的查询速度,但是会降低插入、删除、更新表的速度,因为在执行这些写操作时,还要操作索引文件。 简单的例子 主键A跟主键B组成联合主键C,主键A跟主键B的数据可以完全相同,联合就在于主键A跟主键B形成的联合主键C是唯一的。

  • 6
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

迷你酷吧

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值