登录  /  注册

mysql复合主键是什么意思

青灯夜游
发布: 2023-03-30 10:15:29
原创
3799人浏览过

mysql中,复合主键是指数据库表的主键含有一个以上的字段组成,即多字段主键;复合主键是主键的一种,与主键具有相同的功能和定义。复合主键不能包含不必要的多余列;当把复合主键的某一列删除后,如果剩下的列构成的主键仍然满足唯一性原则,那么这个复合主键是不正确的。

mysql复合主键是什么意思

本教程操作环境:windows7系统、mysql8版本、Dell G3电脑。

什么是数据表的复合主键 ?

所谓的复合主键,就是指你表的主键含有一个以上的字段组成 。

MySQL多字段主键又可以成为复合主键。复合主键也是主键的一种与主键具有相同的功能和定义。

主键约束即在表中定义一个主键来唯一确定表中每一行数据的标识符。主键可以是表中的某一列或者多列的组合,其中由多列组合的主键称为复合主键。

复合主键不能包含不必要的多余列。当把复合主键的某一列删除后,如果剩下的列构成的主键仍然满足唯一性原则,那么这个复合主键是不正确的。这是最小化原则。

例如:

create table test
(
name varchar(19),
id number,
value varchar(10),
primary key (name,id)
)
登录后复制

上面的name和id字段组合起来就是你test表的复合主键

它的出现是因为你的name字段可能会出现重名,所以要加上ID字段这样就可以保证你记录的唯一性

为什么会出现复合主键

这是因为表name字段可能出现重名的情况,所以要加上id字段来保证记录的唯一性,而我们在开发中,主键字段数是保持一个是比较好的,非要创建两个复合主键,那么在创建表的时候就应该寻找一个能唯一性标识该对象的一个字段来识别。

那么问题又来了,不是说一个表只能有一个主键吗?主键是一个表的唯一索引啊,那么为何一个表可以创建多个主键呢?

其实“主键是唯一的索引”这话有点歧义的,举个例子说明:我们习惯性的在表中都会有一个id字段,设置为自动增长,并设置为主键,这时候"主键是唯一的索引",id自动增长保证来唯一性。此时,在创建一个字段name varchar(50),也被设置为了主键,这时候id和name就成为了复合主键了,而表中的name字段在插入数据时是可以插入相同的name值的,这时候又有问题了,不是说"主键是唯一索引吗?怎么能有相同的值?"

所以说"主键是唯一性索引"是有歧义的;主键是唯一性索引的前提是"当表中只有一个主键时,它才是唯一的索引;当表中有多个主键时,称为复合主键,复合主键联合保证唯一性索引,即可理解为复合主键联合起来成为了一个表的唯一性索引(主键)"。为什么自增长ID已经可以作为唯一标识的主键,为啥还需要复合主键呢?因为,并不是所有的表都要有id这个字段啊,比如,我们建一个学生表,没有唯一能标识学生的ID,怎么办呢?学生的名字、年龄、班级都可能重复,无法使用单个字段来唯一标识,这时,我们可以将多个字段设置为主键,形成复合主键,这多个字段联合标识唯一性,其中,某几个主键字段值出现重复是没有问题的,只要不是有多条记录的所有主键值完全一样,就不算重复。

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

如何添加复合主键?

可以在创建表时添加复合主键,此时主键由多个字段联合组成,语法规则如下:

PRIMARY KEY [字段1,字段2,…,字段n]
登录后复制

示例:创建数据表 tb_emp,假设表中没有主键 id,为了唯一确定一个员工,可以把 name、deptId 联合起来作为主键

mysql> CREATE TABLE tb_emp
    -> (
    -> name VARCHAR(25),
    -> deptId INT(11),
    -> salary FLOAT,
    -> PRIMARY KEY(id,deptId)
    -> );
Query OK, 0 rows affected (0.37 sec)
登录后复制

1.png

联合主键

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

学生表: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是唯一的。

【相关推荐:mysql视频教程

以上就是mysql复合主键是什么意思的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号