mysql关于or的索引的问题及解决

 更新时间:2023年08月30日 10:05:00   作者:某科学的南条  
这篇文章主要介绍了mysql关于or的索引的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

mysql关于or的索引问题

用UNION替换OR (适用于索引列)

在下面的例子中,LOC_ID 和REGION上都建有索引*

高效:

select loc_id , loc_desc , region from location where loc_id = 10   
union   
select loc_id , loc_desc , region  from location where region = "melbourne"   

低效:

select loc_id , loc desc , region from location where loc_id = 10 or region = "melbourne" 

如果你坚持要用OR,那就需要返回记录最少的索引列写在最前面。

mysql or不走索引分析

select * from tableName where a=1 and (b=1 or c=1)

其中建立了ab和ac的联合索引,但是看db监控慢查询的扫描行数和a=1的行数相同。

通过explain看出执行计划是走ab的联合索引,但是为啥扫描行数却是a=1的行数呢?

猜测是因为要查a=1 and b=1的数据时候,可以走ab索引,但是查出 a=1和c=1的数据,就需要扫描a=1的所有数据。

可以通过联合索引的数据结构看出,当a相同时候,会按照b来排序。

而且mysql一般不会选择走多个索引,除非要索引合并,但是通过explain看出来并没有索引合并。

所以只会走ab的索引&扫描a=1的所有数据来获取c=1的数据。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • mysql索引对排序的影响实例分析

    mysql索引对排序的影响实例分析

    这篇文章主要介绍了mysql索引对排序的影响,结合实例形式分析了mysql使用索引提高排序速度的相关操作技巧,需要的朋友可以参考下
    2019-07-07
  • MySql中如何使用 explain 查询 SQL 的执行计划

    MySql中如何使用 explain 查询 SQL 的执行计划

    explain命令是查看查询优化器如何决定执行查询的主要方法。这篇文章重点给大家介绍MySql中如何使用 explain 查询 SQL 的执行计划,感兴趣的朋友一起看看吧
    2018-05-05
  • mysql实现按组区分后获取每组前几名的sql写法

    mysql实现按组区分后获取每组前几名的sql写法

    这篇文章主要介绍了mysql实现按组区分后获取每组前几名的sql写法,具有很好的参考价值,希望对大家有所帮助。
    2023-03-03
  • MySQL中like的模糊查询优化以及虚拟列功能详解

    MySQL中like的模糊查询优化以及虚拟列功能详解

    在数据库查询场景中,LIKE操作符的模糊匹配是高频需求,但传统写法往往导致全表扫描,成为性能瓶颈,这篇文章主要介绍了MySQL中like的模糊查询优化以及虚拟列功能的相关资料,需要的朋友可以参考下
    2026-03-03
  • MySql分库分表深度指南之从策略到落地

    MySql分库分表深度指南之从策略到落地

    文章介绍了MySQL分库分表的策略及实施方法,包括分片键设计、中间件选型(如ShardingSphere、Mycat),以及如何处理跨分片查询和数据迁移,通过案例和最佳实践,文章展示了如何解决高并发、大数据量下的查询和事务问题,实现数据自治和高可用,感兴趣的朋友跟随小编一起看看吧
    2026-01-01
  • mysql8.0主从复制搭建与配置方案

    mysql8.0主从复制搭建与配置方案

    MySQL主从复制是一个异步的复制过程,就是有两个数据库服务器,一个是主(master)数据库服务器,另一个是从(slave)数据库服务器。
    2022-09-09
  • MySQL系列教程小白数据库基础

    MySQL系列教程小白数据库基础

    这篇文章主要为大家介绍了MySQL系列中的数据库基础,非常适合数据库小白的入门基础篇,详细的讲解了数据库的基本概念以及基础命令及操作示例,有需要的朋友可以借鉴参考下
    2021-10-10
  • 全面了解mysql中utf8和utf8mb4的区别

    全面了解mysql中utf8和utf8mb4的区别

    下面小编就为大家带来一篇全面了解mysql中utf8和utf8mb4的区别。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • MySQL对前N条数据求和的几种方案

    MySQL对前N条数据求和的几种方案

    本文详细介绍了在MySQL中计算分组数据中排名前N的记录的合计值的几种方法,通过对比不同的解决方案,推荐使用窗口函数和临时表的结合方案,以提高查询性能,需要的朋友可以参考下
    2026-01-01
  • MySQL中的聚簇索引、非聚簇索引、联合索引和唯一索引详细介绍

    MySQL中的聚簇索引、非聚簇索引、联合索引和唯一索引详细介绍

    本文主要介绍了MySQL的索引类型,根据索引的存储方式来划分,索引可以分为聚簇索引和非聚簇索引。聚簇索引的特点是叶子节点包含了完整的记录行,而非聚簇索引的叶子节点只有所以字段和主键ID,感兴趣的同学可以阅读本文
    2023-04-04

最新评论