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 有任务来将数据进行 "物理删除", 可以参见后面的 数据记录的增删改查 的文章

索引记录信息如下

相关推荐
xiaok3 小时前
GROUP BY进阶用法
mysql
李慕婉学姐3 小时前
【开题答辩过程】以《基于Android的健康助手APP的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
android·java·mysql
qq_12498707533 小时前
基于springboot健康养老APP的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·mysql·微信小程序·毕业设计
亚林瓜子3 小时前
mysql命令行手动导入csv数据到指定表
数据库·mysql·gui·csv·cli·db·import
一分半心动4 小时前
lnmp架构 mysql数据库Cannot assign requested address报错解决
linux·mysql·php
ChristXlx4 小时前
Linux安装mysql(虚拟机适用)
linux·mysql
瀚高PG实验室5 小时前
timestampdiff (MYSQL)函数在Highgo DB中的写法
数据库·mysql·瀚高数据库
还是鼠鼠5 小时前
SQL语句执行很慢,如何分析呢?
java·数据库·mysql·面试
云和数据.ChenGuang5 小时前
批量给100台服务器装系统,还要完成后续的配置和软件部署
运维·服务器·开发语言·mysql
程序员卷卷狗6 小时前
为什么MySQL默认使用可重复读RR?深入解析binlog与隔离级别的关系
数据库·mysql