【二十二、MySql】进阶篇--索引--使用规则--最左前缀法则 和 范围查询

索引使用规则

1, 最左前缀法则:适用于联合索引

在这里插入图片描述

知识点:查询时,必须包含最左边的那个列,在此案例中即列phone。

前置:创建联合索引:为表employee创建(phone,age,status)三个字段的联合索引
在这里插入图片描述

案例分析:
【情景一】执行如下SQL,where phone,age,status三个字段,而且中间并未跳过任何一列,查看执行计划
现象:索引长度43
在这里插入图片描述
解析:最左边字段存在,没有跳过任何列
结论:索引生效

【情景二】执行如下SQL,保留phone,age,去掉status的条件,查看执行计划
现象:索引长度为39,说明status字段的索引长度为4,phone字段的索引为35
在这里插入图片描述
解析:最左边字段存在,跳过了status字段的索引
结论:索引生效

【情景三】执行如下SQL,保留phone,去掉age , status的条件,查看执行计划
现象:索引长度为35,说明age字段的索引长度为4
在这里插入图片描述
解析:最左边字段存在
结论:索引生效

【情景四】执行如下SQL,去掉phone字段的条件,保留age , status的,查看执行计划
在这里插入图片描述
解析:最左字段不存在,不满足最左前缀法则
结论:索引全部失效,全表扫描

【情景五】执行如下SQL,保留phone,跳过age ,保留 status字段,查看执行计划
现象:索引长度只有35,说明status字段索引失效
在这里插入图片描述
解析:最左字段虽然存在,但是跳过字段
结论:索引部分失效

【情景六】执行如下SQL,保留phone,age ,status字段,但是phone放在其他位置,查看执行计划
现象:索引长度为43
在这里插入图片描述
解析:索引当中最左边字段只要存在,与放置的位置无关
结论:索引生效

2,范围查询 指的也是复合索引中的范围查询
知识点:范围查询右边的列索引将会失效
在这里插入图片描述

【情景一】执行如下SQL,查看执行计划
现象:索引长度为39,status字段的索引失效
在这里插入图片描述
解析:使用了范围查询,范围查询右边的列索引将会失效
结论:索引部分失效

规避方案:在业务允许的范围尽量使用>= 或 <=的范围查询,如下:
索引长度为43,说明三个字段的索引都用上了
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,关于 Docker 数据卷的进阶篇,我可以为你提供以下内容: 1. 数据卷的类型 Docker 数据卷有三种类型:主机挂载、匿名卷、命名卷。其中,主机挂载是将主机上的目录挂载到容器中;匿名卷是在容器内部创建的临时卷;命名卷则是给卷起一个名字,并将其保存在 Docker 数据卷存储区中。 2. 数据卷的备份与恢复 我们可以使用 Docker Compose 中的 `docker-compose.yml` 文件来定义数据卷的备份和恢复。具体方法是,在 `volumes` 字段中定义卷及其备份路径,然后在 `services` 字段中指定容器和对应的卷名称。 例如: ``` version: "3" services: db: image: mysql volumes: - db_data:/var/lib/mysql command: --default-authentication-plugin=mysql_native_password backup: image: backup volumes: - /path/to/backup:/backup - db_data:/data/db command: backup.sh volumes: db_data: ``` 以上代码中,我们定义了一个 `db` 服务和一个 `backup` 服务。其中,`db` 服务使用了名为 `db_data` 的命名卷,并挂载到容器的 `/var/lib/mysql` 目录中;`backup` 服务则使用了两个卷,一个是挂载到宿主机上的 `/path/to/backup` 目录,用于保存备份文件;另一个是使用了 `db_data` 命名卷,并挂载到容器的 `/data/db` 目录中,用于备份数据。最后,我们在 `backup` 服务中执行了备份脚本 `backup.sh`。 3. 数据卷的共享 我们可以将一个数据卷挂载到多个容器中,实现数据的共享。例如,我们可以将一个命名卷挂载到 `web` 和 `db` 两个服务中,这样它们就可以共享数据了。 ``` version: "3" services: web: image: nginx volumes: - web_data:/usr/share/nginx/html db: image: mysql volumes: - db_data:/var/lib/mysql - web_data:/var/www/html volumes: db_data: web_data: ``` 以上代码中,我们定义了一个 `web` 服务和一个 `db` 服务。其中,`web` 服务使用了名为 `web_data` 的命名卷,挂载到容器的 `/usr/share/nginx/html` 目录中;`db` 服务则使用了 `db_data` 和 `web_data` 两个卷,分别挂载到容器的 `/var/lib/mysql` 和 `/var/www/html` 目录中,实现了数据的共享。 希望以上内容能够对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值