首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql为主键加索引吗

基础概念

MySQL中的主键(Primary Key)是一种特殊的唯一索引,用于唯一标识表中的每一行数据。主键具有以下特性:

  1. 唯一性:主键的值必须是唯一的,不允许有重复的值。
  2. 非空性:主键的值不能为空。
  3. 唯一索引:主键自动创建一个唯一索引,以提高查询效率。

相关优势

  1. 唯一性保证:主键确保每一行数据的唯一性,避免数据重复。
  2. 快速查找:由于主键自动创建唯一索引,可以快速定位到特定的记录。
  3. 数据完整性:主键的非空性保证了数据的完整性,避免了空值的出现。

类型

MySQL中的主键可以是以下几种类型:

  1. 单列主键:使用单个列作为主键。
  2. 单列主键:使用单个列作为主键。
  3. 复合主键:使用多个列作为主键。
  4. 复合主键:使用多个列作为主键。
  5. 自增主键:使用自增列作为主键,通常用于生成唯一的标识符。
  6. 自增主键:使用自增列作为主键,通常用于生成唯一的标识符。

应用场景

主键广泛应用于各种数据库表中,特别是在需要唯一标识每一行数据的场景中,例如:

  • 用户表:每个用户需要一个唯一的ID。
  • 订单表:每个订单需要一个唯一的订单号。
  • 产品表:每个产品需要一个唯一的产品ID。

遇到的问题及解决方法

问题:为什么不能在主键上使用NULL值?

原因:主键的非空性是MySQL设计的一部分,确保每一行数据都有一个唯一的标识符。如果允许主键为NULL,那么可能会出现多行数据的主键都为NULL的情况,这违背了主键的唯一性原则。

解决方法:在设计表结构时,确保主键列不允许NULL值。

代码语言:txt
复制
CREATE TABLE users (
    id INT NOT NULL PRIMARY KEY,
    name VARCHAR(50)
);

问题:为什么复合主键的性能可能不如单列主键?

原因:复合主键由于涉及多个列,索引的大小会比单列主键大,这可能导致查询性能下降。

解决方法:在设计表结构时,尽量使用单列主键,或者优化复合主键的使用场景。

代码语言:txt
复制
CREATE TABLE orders (
    order_id INT PRIMARY KEY,
    user_id INT,
    FOREIGN KEY (user_id) REFERENCES users(id)
);

参考链接

通过以上信息,您可以更好地理解MySQL主键的概念、优势、类型、应用场景以及常见问题的解决方法。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQL ORDER BY主键id加LIMIT限制走错索引

背景及现象 report_product_sales_data表数据量2800万; 经测试,在当前数据量情况下,order by主键id,limit最大到49的时候可以用到索引report_product_sales_data_hq_code_orgz_id_index...,大于49时就走PRIMARY主键索引。...在order by 主键id时,limit值的大小达到了某个临界值后,改变了执行计划,选择了主键索引,但不知道具体的规则究竟是怎样。...由于自身的优化器选择,为了避免某些排序的消耗,可能会走非预期的PRIMARY主键索引; order by 和 limit 结合使用,如果where 字段,order by字段都是索引,那么有limit索引会使用...查看是否使用到了最优索引; 利用optimizer trace查看优化器执行过程; 观察mysql的slow_query_log,及时做排查优化。

1.8K10

MySQL ORDER BY主键id加LIMIT限制走错索引

背景及现象 report_product_sales_data表数据量2800万; 经测试,在当前数据量情况下,order by主键id,limit最大到49的时候可以用到索引report_product_sales_data_hq_code_orgz_id_index...,大于49时就走PRIMARY主键索引。...在order by 主键id时,limit值的大小达到了某个临界值后,改变了执行计划,选择了主键索引,但不知道具体的规则究竟是怎样。...由于自身的优化器选择,为了避免某些排序的消耗,可能会走非预期的PRIMARY主键索引; 对于数据量比较大,而且执行量很高的分页sql,尽可能将所有的查询字段包括在索引中,同时使用索引来消除排序; 多用explain...查看是否使用到了最优索引; 利用optimizer trace查看优化器执行过程; 观察mysql的slow_query_log,及时做排查优化。

6.7K32
  • MySQL 核心模块揭秘 | 35 期 | 主键索引等值查询加什么锁?

    本文基于 MySQL 8.0.32 源码,存储引擎为 InnoDB。 正文 1....可重复读隔离级别下,对 where 条件覆盖范围内的记录默认加 Next-Key 锁,既锁住索引记录本身,防止其它事务修改或者删除记录,又锁定索引记录前面的间隙,防止其它事务往间隙中插入记录。...示例 SQL 的 where 条件中只包含主键索引字段,主键索引的唯一约束能够保证:只要不删除表中 的记录,就不会再有其它 的记录插入到主键索引中。...示例 SQL 执行过程中,对主键索引中 的记录加共享普通记录锁,属于默认情况,不需要其它解释了。 4....总结 可重复读、读已提交两种隔离级别下,对主键索引字段进行等值查询,虽然都对记录加了共享普通记录锁,但是它们的加锁逻辑是不一样的。 这两种隔离级别下,对唯一索引进行等值查询,加锁情况是什么样的呢?

    10610

    mysql 如何加索引_mysql如何添加索引

    在mysql中可以在创建表(CREATE TABLE)的同时创建索引;也可以在创建表后创建索引,使用CREATE INDEX语句或ALTER TABLE 语句。...(视频教程推荐:mysql视频教程) 1、使用CREATE INDEX语句 可以使用专门用于创建索引的 CREATE INDEX 语句在一个已有的表上创建索引,但该语句不能创建主键。...二、使用 CREATE TABLE 语句 索引可以在创建表(CREATE TABLE)的同时创建,语法格式: 1、创建主键索引CONSTRAINT PRIMARY KEY [索引类型] (,…) 在使用...而当主键是由多个列组成的多列索引时,则不能使用这种方法,只能用在语句的最后加上一个 PRIMARY KRY(,…) 子句的方式来实现。...1、创建主键索引ADD PRIMARY KEY [] (,…) 2、创建一般索引ADD INDEX [] [] (,…) 3、创建唯一性索引ADD UNIQUE [ INDEX | KEY] [] []

    7.4K20

    面试突击57:聚簇索引=主键索引吗?

    一般情况下,聚簇索引等同于主键索引,但这里有一个前提条件,那就是这张表需要有主键,只有有了主键,它才能有主键索引,有主键索引才能等于聚簇索引。...所以看到这里,我们应该明白一个道理:聚簇索引并不完全等于主键索引,因为一张表从结构上来讲,可以没有主键(索引),如果没有主键(索引),那么聚簇索引就不再是主键索引了。...聚簇索引诞生过程 在 InnoDB 引擎下,聚簇索引的诞生过程如下: 当你为一张表创建主键时,也就是定义 PRIMARY KEY 时,此时这张表的聚簇索引就是主键索引。...总结 在 InnoDB 引擎中,每张表都会有一个特殊的索引“聚簇索引”,一般情况下聚簇索引等于主键索引,但聚簇索引又不完全等于主键索引,因为一张表中没有主键索引,那么聚簇索引会使用第一个唯一索引(此列必须为...参考 & 鸣谢 dev.mysql.com/doc/refman/5.7/en/innodb-index-types.html 是非审之于己,毁誉听之于人,得失安之于数。

    2.2K61

    MySQL 核心模块揭秘 | 32 期 | 插入记录,主键索引冲突加什么锁?

    本文基于 MySQL 8.0.32 源码,存储引擎为 InnoDB。 正文 1....原理分析 insert 语句执行过程中,插入记录到主键索引之前,需要先找插入记录的目标位置。 目标位置为表中主键字段值小于等于新插入记录中主键字段值的最后一条记录之后。...以示例 SQL 为例,插入主键字段 的记录。 插入记录到主键索引之前,先找到表中 id 小于等于 10 的最后一条记录,也就是 这条记录。...InnoDB 发现表中已经有一条 的记录,现在又要插入一条 的记录,可是主键索引中不允许存在重复记录,这可怎么办才好? 直接报错吗?...为了防止其它事务更新或者删除这条记录,检查表中记录是否有效之前,InnoDB 会对这条记录加共享普通记录锁。 这就是示例 SQL 执行过程中对 的记录加共享普通记录锁的原因。

    9710

    主键索引就是聚集索引?MySQL 索引类型大梳理

    之前松哥在前面的文章中介绍 MySQL 的索引时,有小伙伴表示被概念搞晕了,主键索引、非主键索引、聚簇索引、非聚簇索引、二级索引、辅助索引等等,今天咱们就来捋一捋这些概念。 1....全文索引在 MySQL 中支持的版本也需要大家留意一下: MySQL 5.6 以前的版本,只有 MyISAM 存储引擎支持全文索引。...创建全文索引对字段类型也有要求,只有字段的数据类型为 CHAR、VARCHAR 以及 TEXT 等才可以建立全文索引。...MySQL 的全文索引最开始只支持英文,因为英文分词比较方便;中文分词就比较麻烦,所以最早的 MySQL 全文索引是不支持中文的。...不过 MySQL 的全文索引并不好用,有这方面的需求还是直接上 Es 吧。

    2.3K20

    mysql 唯一索引_mysql主键和唯一索引的区别

    Mysql索引大概有五种类型: 普通索引(INDEX):最基本的索引,没有任何限制 唯一索引(UNIQUE):与”普通索引”类似,不同的就是:索引列的值必须唯一,但允许有空值。...主键索引(PRIMARY):它 是一种特殊的唯一索引,不允许有空值。...全文索引(FULLTEXT ):可用于 MyISAM 表,mysql5.6之后也可用于innodb表, 用于在一篇文章中,检索文本信息的, 针对较大的数据,生成全文索引很耗时和空间。...联合(组合)索引:为了更多的提高mysql效率可建立组合索引,遵循”最左前缀“原则。 这里我们来看下唯一索引。...之前我们看了主键索引,他是一种特殊的唯一索引,二者的区别是,主键索引不能有空值,但是唯一索引可以有空值。

    2.9K30

    MySQL中主键为0和主键自排约束的关系

    现在主键是没有0的,如果把某个id改成0的话,0不会变!...如果使用主键自排约束以前表里有0,再设置完主键自排以后所有的0又不会根据行数,而是直接按照自上而下的顺序从1开始排。...如果把表中的某个主键的数改成0,那直接就会进行排序放到正数前面,也就是说主键自排是允许有0存在的,那为什么本身存在的0要去修改成从1开始的递增序列呢?...哪怕没加主键自排以前只有一个0,加了主键自排以后还是会变成1。   开始有0,增加主键自排约束,0依次变为1,2,3,4.......   ...开始没0,增加主键自排约束,新添加的主键是0的行会根据行数自行变化,注意这里是新添加的行,使用的是insert。   开始没0,把某个主键的数修改成0,这个0会直接在排好序了再在表里显示出来。

    4.3K30

    MySQL给字符串加索引

    MySQL是支持前缀索引的,前缀索引的优势就是占用的空间小,这同时带来的损失是,可能会增加额外的记录扫描次数。...,那这些语句就只能做全表扫描 MySQL 是支持前缀索引的,可以定义字符串的一部分作为索引。...这个过程中,只需要回主键索引取一次数据,所以系统认为只扫描了一行。...如果使用的是 index2(即 email(6) 索引结构),执行顺序是这样的: 从 index2 索引树找到满足索引值是’zhangs’的记录,找到的第一个是 ID1; 到主键上查到主键值是 ID1...有以下2中方式 就是使用倒序存储,比如身份证倒序,查询的时候再用函数转一下 以及使用hash字段,在表上创建一个整数字段,来保存身份证的校验码,同时在这个字段上加索引 这两种方式对比区别 从占用的额外空间来看

    2.5K71

    mysql主从延迟案例(有索引但无主键)

    导读mysql的主从延迟问题还是很常见的, 通常都是没得索引或者数据量太大导致的. 如果有索引,选择性不好,还是会导致主从延迟增大....解决方案方案1加主键然后重建主从. 这是最稳妥的方法, 如果数据量太大的话, 也可以选择只重建某张表....基础操作了,就不演示了.注意:直接加自增列有数据不一致的风险(今天刚看到有大佬文章在讲), 加完后重建主从就没那么多问题了.方案2还有种花里胡哨的方法, 就是设置回放的算法为hash_scan, 这样每次扫描就会快很多...我这里就简单使用checksum table来校验了数据当然是一致的啦(hash碰撞的概率非常低的, 而且hash_scan是8.0的默认选择)总结mysql的表都建议加上主键/唯一键, 实在没得选的,...可以整联合主键, 还是选不上的, 就普通索引吧, 但前提是选择性好一点的.

    18531

    Innodb加索引,这个时候会锁表吗?

    以索引创建为例: image.png 从上文可见,当我们创建、删除或重命名索引时,会采用“in place”的模式。...对原表加共享 MDL 锁,阻止对原表的写操作,仅允许查询操作。 逐行将原表数据拷贝到临时表中,且无需进行排序。 数据拷贝完成后,将原表锁升级为排他 MDL 锁,阻止对原表的读写操作。...创建索引数据字典。 对原表加共享 MDL 锁,阻止对原表的写操作,只允许查询操作。 根据聚集索引的顺序,查询表中的数据,并提取所需的索引列数据。将提取的索引数据进行排序,并插入到新的索引页中。...inplace-rebuild:修改主键索引、增加或删除列、修改字符集、创建全文索引等操作需要重建原表。...Execute 阶段: 降级 EXCLUSIVE-MDL 锁为 SHARED-MDL 锁,允许读写操作。 扫描原表聚集索引的每一条记录。 遍历新表的聚集索引和二级索引,逐一处理。

    55810
    领券