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

mysql 添加索引慢

基础概念

MySQL中的索引是一种数据结构,用于快速查询、更新数据库表中的数据。索引可以显著提高查询速度,但同时也会增加写操作的开销,因为索引本身也需要维护。

相关优势

  1. 提高查询速度:索引可以减少数据库需要扫描的数据量,从而加快查询速度。
  2. 优化排序和分组:索引可以帮助数据库更快地进行排序和分组操作。
  3. 唯一性约束:通过创建唯一索引,可以确保表中的某些列的值是唯一的。

类型

  1. 单列索引:在单个列上创建的索引。
  2. 复合索引:在多个列上创建的索引。
  3. 唯一索引:确保索引列的值是唯一的。
  4. 全文索引:用于全文搜索的索引。

应用场景

  • 频繁查询的列:对于经常用于查询条件的列,添加索引可以显著提高查询速度。
  • 排序和分组:对于经常需要排序和分组的列,添加索引可以提高这些操作的效率。
  • 唯一性约束:对于需要确保数据唯一性的列,可以添加唯一索引。

添加索引慢的原因及解决方法

原因

  1. 数据量大:当表中的数据量很大时,添加索引需要花费更多的时间。
  2. 磁盘I/O性能:如果磁盘I/O性能较差,添加索引的速度会受到影响。
  3. 锁竞争:在添加索引的过程中,可能会产生锁竞争,导致其他操作等待。
  4. 索引类型选择不当:选择了不适合当前查询模式的索引类型。

解决方法

  1. 优化磁盘I/O
    • 使用SSD硬盘。
    • 使用RAID配置提高磁盘读写性能。
  • 减少锁竞争
    • 在低峰期添加索引。
    • 使用ONLINE关键字(MySQL 5.6及以上版本)来在线添加索引,减少锁竞争。
  • 选择合适的索引类型
    • 根据查询模式选择单列索引或复合索引。
    • 对于全文搜索,使用全文索引。
  • 分批添加索引
    • 如果数据量非常大,可以考虑分批添加索引,减少每次操作的数据量。

示例代码

代码语言:txt
复制
-- 添加单列索引
ALTER TABLE table_name ADD INDEX index_name (column_name);

-- 添加复合索引
ALTER TABLE table_name ADD INDEX index_name (column1, column2);

-- 添加唯一索引
ALTER TABLE table_name ADD UNIQUE INDEX index_name (column_name);

-- 在线添加索引(MySQL 5.6及以上版本)
ALTER TABLE table_name ADD INDEX index_name (column_name) ALGORITHM=INPLACE, LOCK=NONE;

参考链接

通过以上方法,可以有效解决MySQL添加索引慢的问题。

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

相关·内容

  • mysql 查看索引添加索引、删除索引命令添加索引删除索引

    查看索引 mysql> show index from tblname; mysql> show keys from tblname; mysql> show index from center_bank_rate...· Non_unique 如果索引不能包括重复词,则为0。如果可以,则为1。 · Key_name 索引的名称。 · Seq_in_index 索引中的列序列号,从1开始。...· Collation 列以什么方式存储在索引中。在MySQL中,有值‘A’(升序)或NULL(无分类)。 · Cardinality 索引中唯一值的数目的估计值。...基数越大,当进行联合时,MySQL使用该索引的机 会就越大。 · Sub_part 如果列只是被部分地编入索引,则为被编入索引的字符的数目。如果整列被编入索引,则为NULL。...· Comment 添加索引 ALTER TABLE Persons ADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName) 删除索引 mysql> alter

    3.4K10

    MySQL 查询、 索引、 事务隔离级别

    查询 什么是查询 MySQL查询日志是 MySQL 提供的一种日志记录,它用来记录在 MySQL 中响应时间超过阀值的语句,阈值指的是运行时间超过 long_query_time 值的 SQL...,则会被记录到查询日志中。...默认情况下,MySQL 数据库并不启动查询日志,需要我们手动来设置这个参数。 查询需要知道的 “点”  企业级开发中,查询日志是会打开的。但是这同样会带来一定的性能影响。...: Usingfilesort: 表示 MySQL 需额外的排序操作,不能通过索引顺序达到排序效果。...=和 in 可以乱序,比如 a = 1 and b = 2 and c = 3 建立(a,b,c)索引可以任意顺序,mysql 的查询优化器会帮你优化成索引 可以识别的形式; 3.

    2.8K50

    MySQL索引原理及查询优化

    本文旨在以开发工程师的角度来解释数据库索引的原理和如何优化查询。...MySQL索引原理 ##索引目的 索引的目的在于提高查询效率,可以类比字典,如果要查“mysql”这个单词,我们肯定需要定位到m字母,然后从下往下找到y字母,再找到剩下的sql。...查询优化 关于MySQL索引原理是比较枯燥的东西,大家只需要有一个感性的认识,并不需要理解得非常透彻和深入。我们回头来看看一开始我们说的查询,了解完索引原理之后,大家是不是有什么想法呢?...比如表中已经有a的索引,现在要加(a,b)的索引,那么只需要修改原来的索引即可 回到开始的查询 根据最左匹配原则,最开始的sql语句的索引应该是status、operator_id、type、operate_time...写在后面的话 本文以一个查询案例引入了MySQL索引原理、优化查询的一些方法论;并针对遇到的典型案例做了详细的分析。

    2.2K30

    MySQL索引原理及查询优化

    在微信公众号"数据库开发"里看到的这篇文章,写的很好,就转载了 出处:美团技术博客 链接:http://tech.meituan.com/mysql-index.html MySQL索引原理及查询优化...本文旨在以开发工程师的角度来解释数据库索引的原理和如何优化查询。...MySQL索引原理 索引目的 索引的目的在于提高查询效率,可以类比字典,如果要查“mysql”这个单词,我们肯定需要定位到m字母,然后从下往下找到y字母,再找到剩下的sql。...查询优化 关于MySQL索引原理是比较枯燥的东西,大家只需要有一个感性的认识,并不需要理解得非常透彻和深入。我们回头来看看一开始我们说的查询,了解完索引原理之后,大家是不是有什么想法呢?...写在后面的话 本文以一个查询案例引入了MySQL索引原理、优化查询的一些方法论;并针对遇到的典型案例做了详细的分析。

    1.1K40

    mysql索引原理与查询优化

    索引的两大类型hash与btree #我们可以在创建上述索引的时候,为其指定索引类型,分两类 hash类型的索引:查询单条快,范围查询 btree类型的索引:b+树,层数越多,数据量指数级增长(我们就用它...age on s1(age);#添加唯一索引 create index name on s1(id,name);#添加联合普通索引 #方法三:ALTER TABLE在已存在的表上创建索引...[(长度)] [asc |desc]) ; #例: alter table s1 add primary key(id);#添加主键索引 2 删除索引 # 删除索引...若想利用索引达到预想的提高查询速度的效果,我们在添加索引时,必须遵循以下原则 #1.最左前缀匹配原则,非常重要的原则, create index ix_name_email on s1(name,email...6.观察结果,不符合预期继续从0分析 八 日志管理 日志 - 执行时间 > 10 - 未命中索引 - 日志文件路径

    2.6K80

    MySQL理解索引添加索引的原则 转

    索引用于快速找出在某个列中有一特定值的行。不使用索引MySQL必须从第1条记录开始然后读完整个表直到找出相关的行,还需要考虑每次读入数据页的IO开销。...MySQL使用B树构造索引的情况下,是由叶子指向具体的页和记录的。并且一个叶子有一个指针指向下一个叶子。...使用索引需要注意: ⑴只对WHERE和ORDER BY需要查询的字段设置索引,避免无意义的硬盘开销; ⑵组合索引支持前缀索引; ⑶更新表的时候,如增删记录,MySQL会自动更新索引,保持树的平衡;因此更多的索引意味着更多的维护成本...所以,大多数情况下,有AB索引了,就可以不用在去建一个A索引了 详解: 联合索引又叫复合索引。对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分。...两个或更多个列上的索引被称作复合索引。 利用索引中的附加列,您可以缩小搜索的范围,但使用一个具有两列的索引 不同于使用两个单独的索引

    1.7K31

    干货:MySQL 索引原理及查询优化

    本文旨在以开发工程师的角度来解释数据库索引的原理和如何优化查询。...MySQL索引原理 索引目的 索引的目的在于提高查询效率,可以类比字典,如果要查“mysql”这个单词,我们肯定需要定位到m字母,然后从下往下找到y字母,再找到剩下的sql。...查询优化 关于MySQL索引原理是比较枯燥的东西,大家只需要有一个感性的认识,并不需要理解得非常透彻和深入。我们回头来看看一开始我们说的查询,了解完索引原理之后,大家是不是有什么想法呢?...比如表中已经有a的索引,现在要加(a,b)的索引,那么只需要修改原来的索引即可 回到开始的查询 根据最左匹配原则,最开始的sql语句的索引应该是status、operator_id、type、operate_time...写在后面的话 本文以一个查询案例引入了MySQL索引原理、优化查询的一些方法论;并针对遇到的典型案例做了详细的分析。

    46430

    【知识】MySQL索引原理及查询优化

    查询优化 4.1 MySQL Explain详解 我们常常用到explain这个命令来查看一个这些SQL语句的执行计划,查看该SQL语句有没有使用上了索引,有没有做全表扫描,这都可以通过explain...如果出现了这个值,那应该注意,根据查询的具体情况可能需要添加索引来改进能。 Impossible where:这个值强调了where语句会导致没有符合条件的行(通过收集统计信息不可能存在结果)。...,随机IO会比顺序IO很多。...参考 (1)MySQL索引原理及查询优化 https://tech.meituan.com/2014/06/30/mysql-index.html (2)MySQL Explain详解 https:...//www.cnblogs.com/tufujie/p/9413852.html (3)MySQL查询优化(线上案例调优)https://www.cnblogs.com/notfound9/p/12928763

    1.1K30

    MYSQL索引原理与查询优化

    组合索引 1.普通索引   普通索引仅有一个功能:加速查询 #创建表同时添加name字段为普通索引 create table tb1( id int not null auto_increment...2.我们可以去mysql的data目录下找到该表,可以看到添加索引后该表占用的磁盘空间多了。 3.如果使用没有添加索引的字段进行条件查询,速度依旧会很慢(如图)。 ?...6、正确使用索引   数据库中添加索引后确实会让查询速度起飞,但前提必须是正确的使用索引来查询,如果以错误的方式使用,则即使建立索引也会不凑效。 即使建立索引索引也不会生效,例如: #1....) EXPLAIN 参数详解: http://www.cnblogs.com/wangfengming/articles/8275448.html  2、日志查询 日志查询 将mysql服务器中影响数据库性能的相关...'; 测试日志查询 #查询时间超过10秒就会记录到查询日志中 select sleep(3) FROM user ; #查看表中的日志 select * from mysql.slow_log

    1.2K130

    MySQL索引原理与查询优化

    唯一索引 主键索引 组合索引 1.普通索引 普通索引仅有一个功能:加速查询 #创建表同时添加name字段为普通索引 create table tb1( id int not null auto_increment...我们可以去mysql的data目录下找到该表,可以看到添加索引后该表占用的硬盘空间多了  3.如果使用没有添加索引的字段进行条件查询,速度依旧会很慢(如图:) ?...6.正确使用索引  数据库表中添加索引后确实会让查询速度起飞,但前提必须是正确的使用索引来查询,如果以错误的方式使用,则即使建立索引也会不奏效。 即使建立索引索引也不会生效,例如: #1....) 10.日志查询 查询日志    将mysql服务器中影响数据库性能的相关SQL语句记录到日志文件,通过对这些特殊的SQL语句分析,改进以达到提高数据库性能的目的。...查看 MySQL日志信息 #.查询日志配置信息 : show variables like '%query%'; #.修改配置信息 set global slow_query_log = on

    1.3K70

    MySQL查询性能,该不该建索引

    日常工作中,有些同学一遇到查询性能问题,就盲目要求 DBA 给表字段创建索引。这种做法对不对呢?今天,我们就来具体看看这背后的细节。 本文的例子均在 MySQL 5.7.26 中执行。...聚簇索引和二级索引 说到索引,页目录就是最简单的索引。但当数据页有无数个时,就需要考虑建立索引,才能定位到记录所在的页。 为了解决这个问题,InnoDB 引入了 B+ 树。...二级索引的维护代价 创建 N 个二级索引,就需要再创建 N 棵 B+ 树,新增数据时不仅要修改聚簇索引,还需要修改这 N 个二级索引。 我们通过实验测试一下创建索引的代价。...创建索引最佳实践 了解了上面的三条代价,现在我们知道,索引并不是解决查询的万能钥匙。这里我总结了三条创建索引的最佳实践供你参考。 第一,无需一开始就建立索引。...一起学习请关注公众号:【杨同学technotes】领取 MySQL 精品技术书籍。

    36130
    领券