26 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 如下 "INSERT INTO `test`.`tz_test_02`(`field1`, `field2`, `field3`) VALUES ('field33', '33', 'field33');"

新增记录的时候的 调用信息如下

待新增的记录信息如下

待新增的索引记录的堆栈信息如下

记录的本身, 和索引记录 是在 row_ins 的循环中, 先增加了记录信息, 然后再增加了记录的索引信息

待新增的索引记录信息如下

索引的更新

执行更新语句如下 "update tz_test_02 set field1 = 'field34' where id = 133;"

会先标记删除 旧的索引记录, 然后再根据新的记录构建 新的索引记录

新增新的索引记录情况如下

索引记录信息如下

索引的删除

执行更新语句如下 "delete from tz_test_02 where id = 133;"

这里先是讲索引记录 逻辑删除了, 然后 之后 mysql 有任务来将数据进行 "物理删除", 可以参见后面的 数据记录的增删改查 的文章

索引记录信息如下

相关推荐
Brookty1 小时前
【MySQL】JDBC编程
java·数据库·后端·学习·mysql·jdbc
_代号0071 小时前
MySQL梳理一:整体架构概览
后端·mysql
码不停蹄的玄黓2 小时前
深入拆解MySQL InnoDB可重复读(RR)隔离级别:MVCC+临键锁如何「锁」住一致性?
数据库·mysql·可重复读
用户91453633083913 小时前
MySQL查询执行顺序:一张图看懂SQL是如何工作的
mysql
Lx3523 小时前
MySQL物化视图:预计算查询结果的定期刷新
sql·mysql·性能优化
Lx3523 小时前
Mysql死锁日志分析:事务逻辑冲突的排查技巧
sql·mysql·性能优化
RainbowSea3 小时前
14. MySQL 锁的详细说明
java·sql·mysql
RainbowSea4 小时前
12 MySQL 数据库其它调优策略
java·sql·mysql
ChinaRainbowSea4 小时前
9-2 MySQL 分析查询语句:EXPLAIN(详细说明)
java·数据库·后端·sql·mysql
deeper_wind4 小时前
MySQL数据库基础(小白的“升级打怪”成长之路)
linux·数据库·mysql