三、联合索引失效场景,哪一个字段使用到了联合索引,根据sql如何建立联合索引

server/2024/9/29 15:42:58/

目录

  • 一、联合索引失效场景
  • 二、哪一个字段使用到了联合索引
  • 三、根据sql如何建立联合索引

一、联合索引失效场景

1、对(a,b,c)创建联合索引

  • where b=2
  • where c=3
  • where b=2 and c=3

以上场景均在在a无序的情况下b、c无法有序

  • where b=2 and a=4
  • where b=2 and c=4 and a=3

以上场景均用上了联合索引,虽然a在条件最后,但优化器会自动调整位置

二、哪一个字段使用到了联合索引

1、对(a,b,c)创建联合索引

  • where a>1 and b=2
    a用到了索引,b没有用到,因为a>1时,b无序
  • where a>=1 and b=2
    ab都用到了索引,有可能存在a=1,b=1;a=1,b=2;a=1;b=3;此时b在a=1时有序,就用上了索引。
  • where a between 2 and 8 and b = 2
    ab都用到了索引,Mysql between 是包含的关系,也就是 >= 且<=
  • where a like ‘j%’ and b=2
    ab都用到了索引,有可能存在a=j,b=1;a=j,b=2;a=j,b=3;此时b在a=j时有序,用上了索引

sql_25">三、根据sql如何建立联合索引

  • where a = 1 and b = 2 and c = 3;
    对(a,b,c)、(b,c,a)、(c,b,a)都可以,优化器会调整顺序
  • where a>1 and b=2;
    对(b,a)建立索引
  • where a>1 and b=2 and c>3;
    对(b,a)、(b,c)建立索引
  • where a=1 order by b;
    对(a,b)建立索引,当a=1,b才有序
  • where a in (1,2,3) and b>1;
    对(a,b)建立索引,in可视为=

http://www.ppmy.cn/server/106118.html

相关文章

Python在excel复制一列到另一个sheet页上

要在Python中复制一个Excel列到另一个sheet页&#xff0c;可以使用openpyxl库。以下是一个简单的例子&#xff0c;演示如何复制列A的所有数据到sheet2的列B。 首先&#xff0c;确保安装了openpyxl库&#xff1a; from openpyxl import load_workbook# 加载Excel文件 wb load…

VMware上Linux系统报错--mount: 在 /dev/sr0 上找不到媒体【解决办法】

问题背景 在VMware上使用CentOS7系统&#xff0c;想要在CentOS7系统上挂载一个镜像文件&#xff0c;在系统下使用mount命令挂载报错如下所示&#xff1a; 解决办法 用lsblk命令查看sr0设备是存在的 查看虚拟机侧问题&#xff0c;右键虚拟机&#xff0c;点击设置 镜像文件已选…

【附源码】Python :三棱锥建模

系列文章目录 Python 建模入门&#xff1a;三棱锥建模 文章目录 系列文章目录一、建模需求二、源代码三、代码分析四、效果展示总结 一、建模需求 使用matplotlib和numpy库来创建一个三棱锥模型。 二、源代码 代码如下&#xff1a; import numpy as np import matplotlib.pyp…

【PyTorch】关于torchvision中的数据集以及dataloader的使用

前提文章目录 【PyTorch】深度学习PyTorch环境配置及安装【详细清晰】 【PyTorch】深度学习PyTorch加载数据 【PyTorch】关于Tensorboard的简单使用 【PyTorch】关于Transforms的简单使用 文章目录 前提文章目录数据集简介程序中下载数据集读取数据集结合transform进行读取数据…

Win11搭建Angular开发环境

作为一名后端程序员&#xff0c;无论当前的工作是否需要&#xff0c;会一点点前端无疑对自己是有帮助的。今天就来介绍一下如何搭建Angular的开发环境。我也是摸着石头过河&#xff0c;所以很多东西也不熟悉&#xff0c;先按照Angular官网的介绍来配置吧。 这个是Angular最新版…

以简单的例子从头开始建spring boot web多模块项目(一)

目的&#xff1a;从头梳理&#xff0c;如何手工从头建立多模块项目。 步骤&#xff1a; 1、建立maven项目,类型&#xff1a;maven Archetype&#xff0c;Name:ParentDemo 选择JDK版本&#xff0c;Archetype&#xff1a;org.apache.maven.archetypes:maven-archetype-quickstart…

Qml Image 截取一部分图片形式

Qml Image 截取一部分 &#xff1a;每次只显示一张图片的一部分&#xff0c;以有不同的状态显示 将这个图形每次只显示一部分出来&#xff1a; 想了好久&#xff0c;才找到实现的方法&#xff1a; 运行效果&#xff1a; 再来一个升级版的小程序&#xff1a; import QtQuick…

014、架构_配置文件_LDS(loadserver.ini)

loadserver.ini 文件说明配置文件“loadserver.ini”用于配置LoadServer模块运行时参数。文件位于用户“~/etc”目录下.配置文件分为: [general]段:配置LoadServer运行中数据文件目录。[transfer]段:配置Transfer运行参数,Transfer安装在数据分片用户下,以LoadServer进程名…