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

MySQL ORDER BY主键idLIMIT限制走错索引

背景及现象 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主键idLIMIT限制走错索引

背景及现象 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.6K32
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    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.3K20

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

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

    1.9K61

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

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

    8510

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

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

    2.2K20

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

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

    2.7K30

    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字段,在表上创建一个整数字段,来保存身份证的校验码,同时在这个字段上索引 这两种方式对比区别 从占用的额外空间来看

    1.9K71

    Innodb索引,这个时候会锁表

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

    31310

    MySQL聚簇索引物理结构及主键查询过程

    数据页分裂的过程,在你不停往表里灌入数据时,会搞出来一个个数据页,若你的主键非自增,他可能会有一个数据行挪动过程,保证你下一个数据页的主键值都大于上一个数据页的主键值。...对此,就得针对主键设计个索引,针对主键索引实际上就是主键目录:把每个数据页的页号,还有数据页里最小的主键值放在一起,组成一个索引的目录 有了上图的主键目录就好多了,直接到主键目录搜索id=3的数据,...此时就会和每个数据页的最小主键来比,首先id=3大于了数据页2里的最小主键值1,接着小于了数据页8里的最小主键值4。...假设有很多数据页,在主键目录里就会有很多数据页和最小主键值,此时完全可二分查找待查询id在哪个数据页。 所以这效率很高,类似上图的主键目录就能认为是主键索引。...数据页都是一坨坨连续数据,放在很多磁盘文件,所以只要你能根据主键索引定位到数据所在的数据页,此时假设我们有别的方式存储了数据页跟磁盘文件的对应关系,此时你就可以找到一个磁盘文件。

    1.2K20

    mysql 索引主键 外键等概念彻底理清楚

    参考文章: Mysql 索引详解和优化 数据库原理-几种数据模型 Mysql中的key和index的区别 (讲的很合理) Mysql中的Cascade,NO ACTION,Restrict...,SET NULL几种功能说明 Mysql中key 、primary key 、unique key 与index区别 重点总结: 1、mysql 的特点: 括号里面是-类型,外面是-名字。...不存在歧义的概念: 1、 primary key 数据库的每张表只能有一个主键,不可能有多个主键。所谓的一张表多个主键,我们称之为联合主键。联合主键就是用多个字段一起作为一张表的主键。...主键主键的作用是保证数据的唯一性和完整性,同时通过主键检索表能够增加检索速度。 唯一性:列可以不唯一,但联合起来必须唯一。...2、 存在歧义的概念: key 和 索引index 1、索引—在SQL语句里叫 key 错综复杂的关系: 1、primary key 与 外键 一图理解: ?

    2.5K10

    mysql中清空表数据,并重置主键1

    MySQL中清空表数据,并重置主键1 ️ 摘要 在本文中,我将向大家展示如何在 MySQL 数据库中清空表的所有数据,并将主键重置 1。...这种情况下,仅仅删除数据是不够的,最好还能将主键(通常是自增的)重置 1。今天,我将向你们展示如何做到这一点。...命令的一个额外好处是,它会重置表的自增主键 1。...如果你想单独重置主键,可以使用 ALTER TABLE 语句,如下: ALTER TABLE table_name AUTO_INCREMENT = 1; 例如,要将 users 表的主键重置 1,你可以这样做...总结 清空 MySQL 表数据并重置主键 1 是一个非常简单但有用的操作,特别是在开发和测试阶段。通过使用 TRUNCATE TABLE 或 ALTER TABLE 语句,你可以轻松完成这个任务。

    33010
    领券