MySQL不适合构建索引及索引失效的情况有哪些

结论

具体案例下文有详尽描述

不适合建立索引的场景:

数据量比较小的表不建议建立索引

有大量重复数据的字段上不建议建立索引(类似:性别字段)

需要进行频繁更新的表不建议建立索引

where、group by、order by后面的没有使用到的字段不建立索引

不要定义冗余索引

索引失效的场景:

过滤条件使用不等于(!=、)

过滤条件使用is not null

在索引字段上使用函数或进行计算

在使用联合索引的时候,需要满足“最佳左前缀法则”,否则失效

当使用了类型转换也会导致索引失效

在使用范围查询的时候,联合索引的部分字段失效(where age >18)

在like字段中,如果是以%开头,索引失效(where name like ‘%abc’)

在使用or进行查询的时候,or前后出现非索引字段,索引失效

表和库的字符集不一致,回导致索引失效

知识点:

每张表的索引不建议超过6个(占用空间、降低表更新速度)

最终到底是否使用索引还是优化器进行决定的

优化器会根据数据量、数据库版本、数据选择读进行查询代价的比较,从而决定是否使用索引

建立索引的时候将需要范围匹配的字段建立在索引的尾部,避免失效

在建立表的时候将字段设置为not null同时设置默认值,当需要查找没有值的记录的时候就可以使用where xxx = 默认值,放置使用is not null导致索引失效

在页面搜索时,请使用左侧或全文模糊匹配(like ‘%abc’)

对于过滤性较好的字段建立在联合索引的前面,这样就可以优先过滤比较多的数据

不建议建立索引的场景

场景一:数据少的表

当数据比较少的时候,索引的优势就不明显了,因为数据库的存储引擎也是非常快的,相较于需要查询索引在进行回表操作,可能直接查询的性能会更高一些,所以数据相对较少的表不建议建立索引

场景二:有大量重复数据的字段

类似于性别字段,只有“男”和“女”两个不同的值,所以索引一半的数据是“男”一半的数据是“女”,那么建立索引并不能进行快速的查询等,所以不建议在有大量重复数据的列上建立索引

场景三:频繁更新的表(update/delete/insert)

因为表中更新数据的时候,索引也是需要进行对应的维护的,如果一个表近期需要频繁的进行增删改操作,那么就需要耗费大量的时间去维护索引,不建议建立索引,可以在需要进行频繁的更新操作的时候将索引删除,更新完毕之后重建索引

场景四:没有使用的字段(where/group by/order by)

不是where/group by/order by后面的字段没有必要建立索引,因为不会使用到该索引

场景五:不要定义冗余索引

create index username_password_address on xiao(username,password,address);-- 如果建立了第一个索引,那么就没有必要建立第二个索引create index username on xiao (username);--第二个索引就是冗余索引,因为第一个已经是先根据username排序的索引--也就是第二个索引的功能完全可以由第一个索引实现

这里因为username作为第一个联合索引的第一个字段,所以索引就是按照username进行排序,在username相同的情况下按照password、address排序,所以也就是实现了单独拿username列作为索引的功能,即第二个索引就是多余的

索引失效的场景

场景一:在建立索引的字段上进行运算(函数等),导致索引失效

这里首先是给age创建了索引,在第一次查询过程中使用了age索引,但是第二次key值为null(索引失效),导致索引失效的原因在于第二次查询的时候where后面对age进行了计算,计算机并不知道执行的是什么计算所以会将age+1计算后与1比较,索引失效

纳米搜索 纳米搜索

纳米搜索:360推出的新一代AI搜索引擎

纳米搜索 30 查看详情 纳米搜索

类似于在字段上使用函数concat()等都会导致索引失效

MySQL不适合构建索引及索引失效的情况有哪些

场景二:使用不等于(where age != 18)

当使用等值运算,那么是可以在索引中进行查找的,但是如果是不等于,那么则需要遍历所有数据,所以所失效

explain select * from xiaoyuanhao where age = 18;explain select * from xiaoyuanhao where age != 18;--这里是在age字段上建立了普通索引,第二个查询时候索引失效

场景三:使用is not null索引失效

与不等于一样,如果使用的是is not null,那么就需要进行全部数据的遍历操作,索引失效,但是如果使用的是is null那么依旧是可以使用索引的

--这里是在age字段上建立了普通索引,第二个查询时候索引失效explain select * from xiaoyuanhao where age is null;--可以正常使用索引explain select * from xiaoyuanhao where age is not null;--索引失效

场景四:在使用联合索引的时候没有遵循最佳左前缀法则

CREATE INDEX age_classid_name ON student(age,classId,NAME);EXPLAIN SELECT * FROM student WHERE classId = 30 AND NAME = 'xiaoyuanhao';-- 因为没有使用age字段,所以没有准许最佳左前缀原则,索引失效

MySQL不适合构建索引及索引失效的情况有哪些

从这里可以看出是没有使用索引的(key = null),因为创建的索引是先按照age进行排序,在age相同的情况下按照classId和name排序,如果在查询的时候需要直接按照classId进行排序查找,那么就无法使用该索引,即索引失效。

如果需要使用使用索引,那么就一定需要到联合索引的第一个字段age,案例如下

EXPLAIN SELECT * FROM student WHERE age = 10 AND NAME = 'xiaoyuanhao';EXPLAIN SELECT * FROM student WHERE age = 10 AND classId = 33 AND NAME = 'xiaoyuanhao';--两者都是使用age字段索引,所以索引有效

MySQL不适合构建索引及索引失效的情况有哪些

MySQL不适合构建索引及索引失效的情况有哪些

场景五:类型转换导致索引失效

CREATE INDEX NAME ON student(NAME);-- 这里的name字段是varchar类型EXPLAIN SELECT * FROM student WHERE NAME = 'xiao';-- 本次查询是可以使用索引的,因为类型都是一致的,都是字符串EXPLAIN SELECT * FROM student WHERE NAME = 123;-- 本次查询则无法使用索引,因为是将数字类型123转换为字符类型

没有发生类型转换,使用索引key = name

MySQL不适合构建索引及索引失效的情况有哪些

发生了类型转换,无法使用索引kye = null,索引失效

MySQL不适合构建索引及索引失效的情况有哪些

使用索引的时候一定需要保证数据类型是一致的,否则系统就需要进行转换,那么就无法使用索引

场景六:使用范围查询导致联合索引其他字段失效

create index age_classId_name on student (age,classId,name);EXPLAIN SELECT * FROM student WHERE age = 10 AND classId > 20 AND NAME = 'xiaoyuanhao';-- 这里只能使用age,classId,索引的前两个字段EXPLAIN SELECT * FROM student WHERE age = 10 AND classId = 20 AND NAME = 'xiaoyuanhao';-- 这里可以使用完整的索引,因为都是等值连接

在classId字段上使用范围查询,导致name字段失效,有效索引长度为63

MySQL不适合构建索引及索引失效的情况有哪些

使用的都是等值匹配,整个索引皆可用,有效索引长度为73

MySQL不适合构建索引及索引失效的情况有哪些

也就是在对于联合索引来说,如果在使用的时候是等值匹配,那么就可以重复的利用索引,如果不是等值匹配,那么该字段也是可以使用索引的,但是该字段右边的字段就将失效

建议在建立索引的时候将需要范围匹配的字段建立在索引的最后面

场景七:在使用like的时候,如果以%开头导致索引失效

EXPLAIN SELECT * FROM student WHERE NAME LIKE 'abc%';-- 可以正常使用索引EXPLAIN SELECT * FROM student WHERE NAME LIKE '%abc';-- 这里在like中,%在前面无法使用索引

key = name,使用了该索引,索引有效

MySQL不适合构建索引及索引失效的情况有哪些

key = null,索引失效

MySQL不适合构建索引及索引失效的情况有哪些

因为建立的索引实际上是按照整个字符串的从第一个开始进行比较排序的,所以在使用like的时候,也只能够重现进行比较,如果使用的是’%abc’,那么查询的就是以abc结尾的数据,无法使用索引

场景八:or前后出现非索引字段,索引失效

-- 该表中只有name字段上的索引CREATE INDEX NAME ON student(NAME);EXPLAIN SELECT * FROM student WHERE NAME = 'xiao';-- 这里是可以使用name索引的EXPLAIN SELECT * FROM student WHERE NAME = 'xiao' OR classId = 1001;-- 这个则无法使用索引,进行的是全表扫描

key = null,无法使用索引,or条件中出现非索引字段

MySQL不适合构建索引及索引失效的情况有哪些

因为如果name不等于’xiao’的时候那么就会继续判断classId是否等于1001,那么实际上还是会进行全表扫描,所以索引失效(也就是进行name判断的时候可以使用索引,但是在判断classId的时候又要全表扫描,那么优化器就直接进行全表扫描),但是如果or前后的字段都有索引了,那么就就会使用索引

以上就是MySQL不适合构建索引及索引失效的情况有哪些的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/262698.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月4日 09:31:37
下一篇 2025年11月4日 09:34:13

相关推荐

  • C++中如何使用类型擦除_运行时多态实现

    c++++中类型擦除是一种在运行时统一处理不同类型的技术,通过隐藏具体类型信息实现手动多态。1. 定义抽象基类作为通用接口;2. 创建模板类实现该接口并转发操作;3. 使用包装类包含模板类实例指针,提供相同方法并转发调用。示例中drawable为抽象基类,circle和square为具体类型,dra…

    2025年12月18日 好文分享
    000
  • 静态检查融合:SonarQube + Clang实现C++自动审计

    静态检查融合是通过结合sonarqube规则引擎与c++lang分析能力提升c++代码审计效果的方法。1. 安装sonarqube服务器并配置数据库;2. 安装sonarscanner并配置环境变量;3. 安装clang及相关开发工具;4. 安装并配置sonarqube cfamily插件;5. 创…

    2025年12月18日 好文分享
    000
  • 什么是C++中的数据库索引优化?

    c++++中的数据库索引优化可以通过以下步骤实现:1)选择正确的索引类型,如b-tree适合范围查询;2)维护索引,平衡读写性能;3)使用复合索引提升多列查询性能;4)通过查询优化和性能监控调整索引策略。 C++中的数据库索引优化?这是一个有趣且复杂的主题,让我们深入探讨一下。 C++虽然主要用于系…

    2025年12月18日
    000
  • C++中的ORM框架是什么?

    c++++中的orm框架是一种工具,通过对象映射到数据库表,简化数据库操作。1)orm框架通过对象操作数据库,提高开发效率和代码可维护性。2)常见框架如cppdb、odb和soci,各有特点。3)使用时需注意映射关系、查询优化和性能考虑。 C++中的ORM(对象关系映射)框架是什么?简单来说,ORM…

    2025年12月18日
    000
  • C语言网络编程中数据库连接的优化措施问答

    优化措施:使用连接池预创建数据库连接,避免连接/断开开销。优化查询语句,只查询必要字段,避免通配符或子查询。使用批处理将多个操作组合成一个请求,减少网络开销。尽量使用乐观的锁定机制,减少锁定粒度。考虑使用无服务器数据库,由供应商管理数据库,减少开销。 C语言网络编程中数据库连接的优化措施 在C语言网…

    2025年12月18日
    000
  • C++ 函数库在哪些场景下使用?

    c++++ 函数库预先定义了代码模块,可用于处理常见任务,广泛应用于:输入/输出操作字符串操作数学运算此外,还有特定领域的场景,如:图形处理网络编程数据库连接示例:使用 matplotlibcpp 函数库绘制折线图,实现了便捷的图形化展示。 C++ 函数库的应用场景 简介C++ 函数库提供了预定义的…

    2025年12月18日
    000
  • C++框架内置功能在跨平台开发中的作用

    在跨平台开发中,c++++ 框架的内置功能发挥着至关重要的作用,包括:跨平台兼容性:在多平台上稳定运行,简化移植。图形用户界面 (gui) 支持:提供跨平台的 gui 库,无需编写平台特定代码。数据库集成:支持多种数据库系统,实现数据访问和操作的跨平台性。网络通信:提供网络通信机制,用于分布式应用程…

    2025年12月18日
    000
  • C++框架中的数据处理和存储机制

    本文介绍了 c++++ 框架中处理和存储数据的关键技术:数据处理:stl 容器(vector、map、set)boost 库(额外容器和算法)eigen 库(优化矩阵和向量)数据存储:关系数据库管理系统(rdbms)(mysql、postgresql、sqlite)文档存储(mongodb、redi…

    2025年12月18日
    000
  • C++框架在行业中的实际案例

    c++++ 框架广泛应用于行业中,提供高效且可维护的代码解决方案。这些框架用于开发跨平台 gui(qt)、科学计算(armadillo、eigen)、线性代数运算(eigen)、计算机视觉(opencv)和高性能网络应用程序(ace)。例如,spotify 使用 boost(线程管理和网络操作)、a…

    2025年12月18日
    000
  • C++框架在后端开发方面的优缺点?

    c++++框架在后端开发中的优缺点:优点:高性能低内存使用跨平台原生数据库支持丰富的库生态缺点:学习曲线陡峭内存管理复杂缺乏动态关注编译时间长缺乏垃圾回收 C++ 框架在后端开发中的优缺点 优点: 高性能: C++ 是一种编译语言,可生成高效机器码,从而实现优异的性能。低内存使用: C++ 提供直接…

    2025年12月18日
    000
  • 在线资源和教程如何帮助降低 C++ 框架的学习难度?

    通过在线资源和教程,你可以降低 c++++ 框架的学习难度:利用官方文档和外部教程学习框架的基本概念和最佳实践。加入 stack overflow 和讨论论坛等社区,寻求具体问题的帮助和支持。通过构建 restful api、数据库应用程序和网络服务器等实战案例,获得实践经验。 通过在线资源和教程降…

    2025年12月18日
    000
  • 不同C++框架在特定领域的专业化和适用性对比

    不同的 c++++ 框架针对特定领域进行了专业化,以优化性能和易用性。对于 web 开发,boost.asio 以其轻量级和跨平台能力脱颖而出。用于 gui 开发的 qt 提供了丰富的功能和跨平台支持,而 qtsql 简化了数据库访问。poco 在网络编程中很突出,openmp 在并行计算中表现出色…

    2025年12月18日
    000
  • C++ 框架如何优化大型项目中资源管理和性能

    c++++ 框架通过资源管理和性能优化,提升了大型项目的效率:资源管理优化:通过资源池和智能指针管理资源,优化分配和释放操作。性能优化:利用并发编程和内存管理库,实现跨平台并发编程和提升内存管理性能。 C++ 框架:优化大型项目中资源管理和性能 大型 C++ 项目经常面临资源管理和性能问题。为了解决…

    2025年12月18日
    000
  • C++ 框架性能基准:与其他语言和平台的比较

    基准测试结果表明,c++++ 框架在 http 请求处理和数据库查询方面表现优异,boost.asio 适用于高并发连接,cpp-httplib 和 libuv 具有较低延迟。开发人员应根据不同场景选择最合适的框架。 C++ 框架性能基准:与其他语言和平台的比较 引言 性能是任何软件应用程序的关键方…

    2025年12月18日
    000
  • C++ 框架在网络安全领域的应用:提升网络抵御能力与威胁防御

    c++++ 框架在网络安全中广泛应用,提升网络抵御和威胁防御能力:高性能:c++ 速度和效率使其适合构建实时网络安全应用。内存管理:c++ 提供对内存的细粒度控制,确保安全和资源高效。跨平台支持:c++ 可在多种平台编译,便于构建跨平台安全解决方案。应用包括:入侵检测系统、防火墙、恶意软件分析和取证…

    2025年12月18日
    000
  • C++ 框架的学习指南:快速上手

    对于使用 c++++ 框架,本指南提供了分步指导,包括:了解基础知识:熟悉框架概念和 oop 原则。探索框架功能:容器、算法、线程管理、网络操作和数据库集成。实战案例:创建一个文件管理程序,演示框架的使用。扩展知识:探索其他框架、参与社区和练习项目。 C++ 框架的学习指南:快速上手 随着 C++ …

    2025年12月18日
    000
  • C++ 框架设计中实现代码重用的技术

    在 c++++ 框架设计中,实现代码重用的技术包括:模板方法模式:定义算法大纲,由子类定义具体步骤。策略模式:分离算法实现和使用对象,提高灵活性。工厂方法模式:创建对象的方法由子类实现,允许创建不同类型对象。抽象工厂模式:创建相关对象家族的方法,无需指定具体类,促进松耦合。单例模式:确保类只有一个实…

    2025年12月18日
    100
  • c++是什么语言

    C++ 是一种通用、面向对象、跨平台的编程语言,由比雅尼·斯特劳斯特鲁普开发于 1985 年。它具有面向对象、跨平台、高效、可扩展和低级控制等特点。C++ 被广泛应用于开发操作系统、数据库管理系统、游戏引擎、网络应用程序和大型企业软件。其优点包括效率高、可移植性好、面向对象和强大;缺点则包括复杂性、…

    2025年12月18日
    000
  • C++ 开源库指南:探索丰富的库资源,拓展编程能力

    c++++开源库为开发者提供了丰富的工具,包括:boost库:提供算法和数据结构,可用于字符串操作和图表处理。eigen:线性代数库。opencv:计算机视觉和机器学习库。qt:跨平台gui框架。mysql connector:与mysql数据库交互的库。wxwidgets:图形用户界面库。选择最合…

    2025年12月18日
    000
  • c++怎么连接数据库

    在C++中,可以使用ODBC或第三方库连接到数据库。ODBC步骤:初始化环境,连接到DBMS。其他库:MySQL Connector/C++、PostgreSQL libpq++、SQLite3,根据数据库类型和需求选择库。 C++连接数据库 在C++中连接数据库,可以使用标准的C++数据库连接库(…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信