27 mysql 组合索引 的存储以及使用

前言

这里来看一下 mysql 中索引的 增删改查

查询在前面的系列文章中都有使用到

这里 来看一下 增删改 的相关实现

索引记录 和 数据记录 的处理方式是一致的

这里来看一下 组合索引 的相关, 以及 特性

组合索引的存储以及使用

创建数据表如下, 除了主键之外, 创建了一个 field1, field2 的一个联合索引

复制代码
CREATE TABLE `tz_test_02` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `field1` varchar(12) DEFAULT NULL,
  `field2` varchar(16) DEFAULT NULL,
  `field3` varchar(24) DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE,
  KEY `idx_composite` (`field1`,`field2`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=100 DEFAULT CHARSET=utf8

将 tz_test 的数据 抽取到 tz_test_02, 然后执行 sql, "update tz_test_02 set field3 = field1;"

执行 sql 如下, "select * from tz_test_02 where field1 = 'field33';"

扫描的记录如下, 可以看到是 走的索引

"field33" 表示的是 field1, "33" 表示的是 field2, 再之后为索引记录映射的主键记录信息

索引记录信息如下

"explpain select * from tz_test_02 where field1 = 'field33';" 结果如下

执行 sql 如下, "select * from tz_test_02 where field2 = 33;"

扫描的记录如下, 可以看到是 走的所有的记录

因为索引的存储是按照顺序存储的 field1,field2 -> id

因此, 查询 field1 的记录可以走索引, 查询 field1 + field2 的记录可以走索引

这个就是 联合索引的左前缀匹配规则的道理

"explpain select * from tz_test_02 where field2 = 33;" 结果如下

相关推荐
淮北4942 小时前
最简单的实验室资产管理系统,使用Flask,mysql,html(四、知识补充)
mysql·flask·html
神仙别闹3 小时前
基于Java+MySQL实现(Web)可扩展的程序在线评测系统
java·前端·mysql
果子⌂5 小时前
Docker-构建镜像并实现LNMP架构
mysql·nginx·docker·容器·架构·php
Trust yourself2436 小时前
使用阿里云/腾讯云安装完成mysql使用不了
mysql·阿里云·腾讯云
亲爱的非洲野猪8 小时前
Oracle与MySQL详细对比
数据库·mysql·oracle
Matrix708 小时前
Navicat实现MySQL数据传输与同步完整指南
数据库·mysql
shepherd1118 小时前
批量update实现方案全面解析与最佳实践,带你掌握到底怎么批量更新最快、性能最高
后端·mysql
程序员岳焱9 小时前
Java 与 MySQL 性能优化:MySQL连接池参数优化与性能提升
后端·mysql·性能优化
没有口袋啦9 小时前
《数据库》第一次作业:MySQL数据库账户及授权
数据库·mysql
星辰离彬9 小时前
Java 与 MySQL 性能优化:MySQL连接池参数优化与性能提升
java·服务器·数据库·后端·mysql·性能优化