您的位置: 翼速应用 > 业内知识 > 数据库 > 正文

详细解析在mysql中主键是否唯一

在mysql中主键是唯一的吗?答案是肯定的。不只是mysql,所有的数据库主键都是唯一,反过来说想将一个表的某个字段设置为主键,该字段的数据必须是唯一的,这个是必要条件。主键值能唯一地标识表中的每一行,通过它可强制表的实体完整性;主键的作用是确定该数据的唯一性,主要是用于和其他表的外键关联,以及本记录的修改与删除。


详细解析在mysql中主键是否唯一


本文适用于windows7系统、mysql8版本、Dell G3电脑。


详细解析在mysql中主键是否唯一


所有的数据库主键都是唯一,反过来说想将一个表的某个字段设置为主键,该字段的数据必须是唯一的,这个是必要条件。


主键(PRIMARY KEY)的完整称呼是“主键约束”,是 MySQL 中使用最为频繁的约束。一般情况下,为了便于 DBMS 更快的查找到表中的记录,都会在表中设置一个主键。


主键分为单字段主键和多字段联合主键,本节将分别讲解这两种主键约束的创建、修改和删除。


使用主键应注意以下几点:


●  每个表只能定义一个主键。


●  主键值必须唯一标识表中的每一行,且不能为 NULL,即表中不可能存在有相同主键值的两行数据。这是唯一性原则。


●  一个字段名只能在联合主键字段表中出现一次。


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


在修改表时添加主键约束


主键约束不仅可以在创建表的同时创建,也可以在修改表时添加。但是需要注意的是,设置成主键约束的字段中不允许有空值。


在修改数据表时添加主键约束的语法格式如下:


ALTER TABLE <数据表名> ADD PRIMARY KEY(<字段名>);


查看 tb_emp2 数据表的表结构,SQL 语句和运行结果如下所示。


DESC tb_emp2;


输出结果


示例:


修改数据表 tb_emp2,将字段 id 设置为主键,SQL 语句和运行结果如下。


ALTER TABLE tb_emp2 ADD PRIMARY KEY(id);


输出结果


通常情况下,当在修改表时要设置表中某个字段的主键约束时,要确保设置成主键约束的字段中值不能够有重复的,并且要保证是非空的。否则,无法设置主键约束。


删除主键约束


当一个表中不需要主键约束时,就需要从表中将其删除。删除主键约束的方法要比创建主键约束容易的多。


删除主键约束的语法格式如下所示:


ALTER TABLE <数据表名> DROP PRIMARY KEY;


示例:


删除 tb_emp2 表中的主键约束,SQL 语句和运行结果如下。


ALTER TABLE tb_emp2 DROP PRIMARY KEY;


输出结果


由于主键约束在一个表中只能有一个,因此不需要指定主键名就可以删除一个表中的主键约束。


关于在mysql中主键是否唯一的详细解析就到这里,翼速应用平台内有更多相关资讯,欢迎查阅!


我来说两句

0 条评论

推荐阅读

  • 响应式布局CSS媒体查询设备像素比介绍

    构建响应式网站布局最常见的是流体网格,灵活调整大小的站点布局技术,确保用户在使用的幕上获得完整的体验。响应式设计如何展示富媒体图像,可以通过以下几种方法。

    admin
  • 提升网站的性能快速加载的实用技巧

    网站速度很重要,快速加载的网站会带来更好的用户体验、更高的转化率、更多的参与度,而且在搜索引擎排名中也扮演重要角色,做SEO,网站硬件是起跑线,如果输在了起跑线,又怎么跟同行竞争。有许多方法可提升网站的性能,有一些技巧可以避免踩坑。

    admin
  • 织梦CMS TAG页找不到标签和实现彩色标签解决方法

    织梦cms是我们常见的网站程序系统的一款,在TAG标签中常常遇到的问题也很多。当我们点击 tags.php 页的某个标签的时候,有时会提示:“系统无此标签,可 能已经移除!” 但是我们检查程序后台,以及前台显示页面。这个标签确实存在,如果解决这个问题那?

    admin
  • HTML关于fieldset标签主要的作用

    在前端开发html页面中常用的标签很多,今天为大家带来的是关于HTML中fieldset标签主要的作用说明,根据技术分析HTML

    admin

精选专题