Mysql使用中的性能优化——索引数对插入操作性能的影响

news2024/11/13 9:39:57

表的索引可以给数据检索提升效率,但是也给表的增删改操作带来代价。本文我们将关注,索引数量对INSERT操作的影响。

结论

索引数的新增会造成INSERT操作效率下降,约每增一个索引会降低10%效率。

实验数据

在这里插入图片描述
可以看到0个索引的效率是7个索引效率的一倍。

测试环境

见《Mysql使用中的性能优化——搭建Mysql的监测服务》

测试代码

DROP DATABASE IF EXISTS testdb;
CREATE DATABASE IF NOT EXISTS testdb;
USE testdb;

DROP TABLE IF EXISTS test_insert_src;
CREATE TABLE test_insert_src (
    id SERIAL PRIMARY KEY,
    name TEXT,
    name1 TEXT,
    name2 TEXT,
    name3 TEXT,
    name4 TEXT,
    name5 TEXT,
    name6 TEXT,
    name7 TEXT,
    name8 TEXT,
    name9 TEXT
) engine=InnoDB;

DROP TABLE IF EXISTS test_insert_0_index;
CREATE TABLE test_insert_0_index (
    id SERIAL PRIMARY KEY,
    name TEXT,
    name1 TEXT,
    name2 TEXT,
    name3 TEXT,
    name4 TEXT,
    name5 TEXT,
    name6 TEXT,
    name7 TEXT,
    name8 TEXT,
    name9 TEXT
) engine=InnoDB;

DROP TABLE IF EXISTS test_insert_1_index;
CREATE TABLE test_insert_1_index (
    id SERIAL PRIMARY KEY,
    name TEXT,
    name1 TEXT,
    name2 TEXT,
    name3 TEXT,
    name4 TEXT,
    name5 TEXT,
    name6 TEXT,
    name7 TEXT,
    name8 TEXT,
    name9 TEXT,
    INDEX name_index (name(32))
) engine=InnoDB;

DROP TABLE IF EXISTS test_insert_2_index;
CREATE TABLE test_insert_2_index (
    id SERIAL PRIMARY KEY,
    name TEXT,
    name1 TEXT,
    name2 TEXT,
    name3 TEXT,
    name4 TEXT,
    name5 TEXT,
    name6 TEXT,
    name7 TEXT,
    name8 TEXT,
    name9 TEXT,
    INDEX name_index (name(32)),
    INDEX name1_index (name1(32))
) engine=InnoDB;

DROP TABLE IF EXISTS test_insert_3_index;
CREATE TABLE test_insert_3_index (
    id SERIAL PRIMARY KEY,
    name TEXT,
    name1 TEXT,
    name2 TEXT,
    name3 TEXT,
    name4 TEXT,
    name5 TEXT,
    name6 TEXT,
    name7 TEXT,
    name8 TEXT,
    name9 TEXT,
    INDEX name_index (name(32)),
    INDEX name1_index (name1(32)),
    INDEX name2_index (name2(32))
) engine=InnoDB;

DROP TABLE IF EXISTS test_insert_4_index;
CREATE TABLE test_insert_4_index (
    id SERIAL PRIMARY KEY,
    name TEXT,
    name1 TEXT,
    name2 TEXT,
    name3 TEXT,
    name4 TEXT,
    name5 TEXT,
    name6 TEXT,
    name7 TEXT,
    name8 TEXT,
    name9 TEXT,
    INDEX name_index (name(32)),
    INDEX name1_index (name1(32)),
    INDEX name2_index (name2(32)),
    INDEX name3_index (name3(32))
) engine=InnoDB;

DROP TABLE IF EXISTS test_insert_5_index;
CREATE TABLE test_insert_5_index (
    id SERIAL PRIMARY KEY,
    name TEXT,
    name1 TEXT,
    name2 TEXT,
    name3 TEXT,
    name4 TEXT,
    name5 TEXT,
    name6 TEXT,
    name7 TEXT,
    name8 TEXT,
    name9 TEXT,
    INDEX name_index (name(32)),
    INDEX name1_index (name1(32)),
    INDEX name2_index (name2(32)),
    INDEX name3_index (name3(32)),
    INDEX name4_index (name4(32))
) engine=InnoDB;

DROP TABLE IF EXISTS test_insert_6_index;
CREATE TABLE test_insert_6_index (
    id SERIAL PRIMARY KEY,
    name TEXT,
    name1 TEXT,
    name2 TEXT,
    name3 TEXT,
    name4 TEXT,
    name5 TEXT,
    name6 TEXT,
    name7 TEXT,
    name8 TEXT,
    name9 TEXT,
    INDEX name_index (name(32)),
    INDEX name1_index (name1(32)),
    INDEX name2_index (name2(32)),
    INDEX name3_index (name3(32)),
    INDEX name4_index (name4(32)),
    INDEX name5_index (name5(32))
) engine=InnoDB;

DROP TABLE IF EXISTS test_insert_7_index;
CREATE TABLE test_insert_7_index (
    id SERIAL PRIMARY KEY,
    name TEXT,
    name1 TEXT,
    name2 TEXT,
    name3 TEXT,
    name4 TEXT,
    name5 TEXT,
    name6 TEXT,
    name7 TEXT,
    name8 TEXT,
    name9 TEXT,
    INDEX name_index (name(32)),
    INDEX name1_index (name1(32)),
    INDEX name2_index (name2(32)),
    INDEX name3_index (name3(32)),
    INDEX name4_index (name4(32)),
    INDEX name5_index (name5(32)),
    INDEX name6_index (name6(32))
) engine=InnoDB;

DROP TABLE IF EXISTS test_insert_8_index;
CREATE TABLE test_insert_8_index (
    id SERIAL PRIMARY KEY,
    name TEXT,
    name1 TEXT,
    name2 TEXT,
    name3 TEXT,
    name4 TEXT,
    name5 TEXT,
    name6 TEXT,
    name7 TEXT,
    name8 TEXT,
    name9 TEXT,
    INDEX name_index (name(32)),
    INDEX name1_index (name1(32)),
    INDEX name2_index (name2(32)),
    INDEX name3_index (name3(32)),
    INDEX name4_index (name4(32)),
    INDEX name5_index (name5(32)),
    INDEX name6_index (name6(32)),
    INDEX name7_index (name7(32))
) engine=InnoDB;

DROP TABLE IF EXISTS test_insert_9_index;
CREATE TABLE test_insert_9_index (
    id SERIAL PRIMARY KEY,
    name TEXT,
    name1 TEXT,
    name2 TEXT,
    name3 TEXT,
    name4 TEXT,
    name5 TEXT,
    name6 TEXT,
    name7 TEXT,
    name8 TEXT,
    name9 TEXT,
    INDEX name_index (name(32)),
    INDEX name1_index (name1(32)),
    INDEX name2_index (name2(32)),
    INDEX name3_index (name3(32)),
    INDEX name4_index (name4(32)),
    INDEX name5_index (name5(32)),
    INDEX name6_index (name6(32)),
    INDEX name7_index (name7(32)),
    INDEX name8_index (name8(32))
) engine=InnoDB;

DROP TABLE IF EXISTS test_insert_10_index;
CREATE TABLE test_insert_10_index (
    id SERIAL PRIMARY KEY,
    name TEXT,
    name1 TEXT,
    name2 TEXT,
    name3 TEXT,
    name4 TEXT,
    name5 TEXT,
    name6 TEXT,
    name7 TEXT,
    name8 TEXT,
    name9 TEXT,
    INDEX name_index (name(32)),
    INDEX name1_index (name1(32)),
    INDEX name2_index (name2(32)),
    INDEX name3_index (name3(32)),
    INDEX name4_index (name4(32)),
    INDEX name5_index (name5(32)),
    INDEX name6_index (name6(32)),
    INDEX name7_index (name7(32)),
    INDEX name8_index (name8(32)),
    INDEX name9_index (name9(32))
) engine=InnoDB;

DROP PROCEDURE IF EXISTS test_insert_proc_batch_bulk;
DELIMITER //
CREATE PROCEDURE test_insert_proc_batch_bulk(IN name TEXT, IN fromNum INT, IN toNum INT)
BEGIN
    DECLARE i INT DEFAULT fromNum;
    DECLARE j INT DEFAULT 0;
    DECLARE new_names TEXT DEFAULT '';
    DECLARE nameList TEXT DEFAULT '';
    SET @sql = 'INSERT INTO test_insert_src (name, name1, name2, name3, name4, name5, name6, name7, name8, name9) VALUES ';
    WHILE i < toNum DO
        SET nameList = '';
        SET j = 0;
        while j < 10 DO
            SET new_names = CONCAT(name, i, "_", j);
            IF j = 0 THEN
                SET nameList = CONCAT(nameList, '"', new_names, '"');
            ELSE
                SET nameList = CONCAT(nameList, ',"', new_names, '"');
            END IF;
            SET j = j + 1;
        END WHILE;
        SET i = i + 1;
        SET @sql = CONCAT(@sql, '(', nameList, '),');
    END WHILE;
    SET @sql = LEFT(@sql, LENGTH(@sql) - 1);
    PREPARE stmt FROM @sql;
    EXECUTE stmt;
    DEALLOCATE PREPARE stmt;
    COMMIT;
END //
DELIMITER ;

DROP PROCEDURE IF EXISTS test_insert_proc_batch;
DELIMITER //
CREATE PROCEDURE test_insert_proc_batch(IN name TEXT, IN count INT, IN step INT)
BEGIN
    DECLARE i INT DEFAULT 0;
    WHILE i < count DO
        CALL test_insert_proc_batch_bulk(name, i, i + step);
        SET i = i + step;
    END WHILE;
    COMMIT;
END //
DELIMITER ;

TRUNCATE TABLE test_insert_src;
CALL test_insert_proc_batch('test', 1000000, 5000);

TRUNCATE TABLE test_insert_0_index;
INSERT INTO test_insert_0_index (name, name1, name2, name3, name4, name5, name6, name7, name8, name9) SELECT name, name1, name2, name3, name4, name5, name6, name7, name8, name9 FROM test_insert_src;  

TRUNCATE TABLE test_insert_1_index;
INSERT INTO test_insert_1_index (name, name1, name2, name3, name4, name5, name6, name7, name8, name9) SELECT name, name1, name2, name3, name4, name5, name6, name7, name8, name9 FROM test_insert_src;

TRUNCATE TABLE test_insert_2_index;
INSERT INTO test_insert_2_index (name, name1, name2, name3, name4, name5, name6, name7, name8, name9) SELECT name, name1, name2, name3, name4, name5, name6, name7, name8, name9 FROM test_insert_src;

TRUNCATE TABLE test_insert_3_index;
INSERT INTO test_insert_3_index (name, name1, name2, name3, name4, name5, name6, name7, name8, name9) SELECT name, name1, name2, name3, name4, name5, name6, name7, name8, name9 FROM test_insert_src;

TRUNCATE TABLE test_insert_4_index;
INSERT INTO test_insert_4_index (name, name1, name2, name3, name4, name5, name6, name7, name8, name9) SELECT name, name1, name2, name3, name4, name5, name6, name7, name8, name9 FROM test_insert_src;

TRUNCATE TABLE test_insert_5_index;
INSERT INTO test_insert_5_index (name, name1, name2, name3, name4, name5, name6, name7, name8, name9) SELECT name, name1, name2, name3, name4, name5, name6, name7, name8, name9 FROM test_insert_src;

TRUNCATE TABLE test_insert_6_index;
INSERT INTO test_insert_6_index (name, name1, name2, name3, name4, name5, name6, name7, name8, name9) SELECT name, name1, name2, name3, name4, name5, name6, name7, name8, name9 FROM test_insert_src;

TRUNCATE TABLE test_insert_7_index;
INSERT INTO test_insert_7_index (name, name1, name2, name3, name4, name5, name6, name7, name8, name9) SELECT name, name1, name2, name3, name4, name5, name6, name7, name8, name9 FROM test_insert_src;

TRUNCATE TABLE test_insert_8_index;
INSERT INTO test_insert_8_index (name, name1, name2, name3, name4, name5, name6, name7, name8, name9) SELECT name, name1, name2, name3, name4, name5, name6, name7, name8, name9 FROM test_insert_src;

TRUNCATE TABLE test_insert_9_index;
INSERT INTO test_insert_9_index (name, name1, name2, name3, name4, name5, name6, name7, name8, name9) SELECT name, name1, name2, name3, name4, name5, name6, name7, name8, name9 FROM test_insert_src;

TRUNCATE TABLE test_insert_10_index;
INSERT INTO test_insert_10_index (name, name1, name2, name3, name4, name5, name6, name7, name8, name9) SELECT name, name1, name2, name3, name4, name5, name6, name7, name8, name9 FROM test_insert_src;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1807531.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Linux】 安装rz 和sz

在 Linux 系统中&#xff0c;rz 和 sz 是两个用于在本地计算机与远程计算机之间安全传输文件的命令行工具。它们是 lrzsz 包的一部分&#xff0c;通常用于通过 SSH 连接传输文件。 打开终端&#xff1a; 首先&#xff0c;打开你的 CentOS 机器上的终端。 执行sz 提示下面信息…

【数据结构(邓俊辉)学习笔记】图05——优先级搜索

文章目录 0. 概述1. BAG2. ADT 0. 概述 学习下优先级搜索 1. BAG 优先级搜索是非常广义的&#xff0c;概况来说&#xff0c;无论DFS 还是BFS从逻辑上来都属于这种搜索。 回忆下什么叫搜索或者遍历&#xff0c;对于像图这种数据结构里的元素逐一的没有重复的也没有遗漏的对它们…

开发uniapp 小程序时遇到的问题

1、【微信开发者工具报错】routeDone with a webviewId XXX that is not the current page 解决方案: 在app.json 中添加 “lazyCodeLoading”: “requiredComponents” uniapp的话加到manifest.json下的mp-weixin 外部链接文章&#xff1a;解决方案文章1 解决方案文章2 &qu…

vs2019 c++20规范 全局函数 ref 及模板类 reference_wrapper<_Ty> 的源码分析

这是个引用&#xff0c;可以包裹一个对象&#xff0c;相当于引用该对象&#xff0c;而不是在作为函数形参时产生值传递。因为模板 reference_wrapper<_Ty> 其实是封装了该对象的地址。下面以图示形式给出其重要的成员函数。模板其实都差不多&#xff0c;跟人也一样&#…

使用Redis的优势以及会引发的问题

优势 ①使用redis代表着高性能还有高并发&#xff0c;高性能很好理解&#xff0c;redis会缓存我们访问的数据。他是基于内存的&#xff0c;第一次访问数据库我们可能需要800ms&#xff0c;但是访问后如果使用redis进行缓存&#xff0c;第二次乃至后面访问相同的数据就只需要去…

Flutter基础 -- Dart 语言 -- 进阶使用

目录 1. 泛型 generics 1.1 泛型使用 1.2 泛型函数 1.3 构造函数泛型 1.4 泛型限制 2. 异步 async 2.1 异步回调 then 2.2 异步等待 await 2.3 异步返回值 3. 生成器 generate &#xff08;了解&#xff09; 3.1 同步生成器 sync* 使用 sync* 的场景 总结 3.2 异…

软件项目调研三部曲(调研计划,调研大纲,调研报告)原件获取

软件项目详细调研的目的是依据项目合同的要求&#xff0c;能够通过在客户现场&#xff0c;并通过访谈的方式&#xff0c;尽可能的了解客户的需求和业务现状&#xff0c;包括客户涉及到的业务部门的岗位设置、岗位职责、工作内容、工作流程、管理难点以及通过实施信息化系统的期…

Silanna UV光荣推出了一款革命性的高功率远紫外线LED

这款令人瞩目的光源&#xff0c;拥有令人震撼的235nm波长&#xff0c;并被巧妙地封装在紧凑的6.8mm结构中&#xff0c;其魅力与实力兼具。 今年六月&#xff0c;在苏格兰圣安德鲁斯大学举行的盛大2024年远紫外科学和技术国际大会&#xff08;ICFUST&#xff09;上&#xff0c;S…

深度剖析AI机会,数字人智能对话系统:未来的人机交互新范式

Datawhale干货 作者&#xff1a;邓恺俊&#xff0c;Datawhale成员 随着人工智能时代的到来&#xff0c;大模型的技术日新月异&#xff0c;我们不仅仅满足于文字之间的交互&#xff0c;希望能够有更近一步的交流。既然现在文字已经能够很好的模拟人类了&#xff0c;那随之而来的…

牛客网刷题 | BC120 争夺前五名

目前主要分为三个专栏&#xff0c;后续还会添加&#xff1a; 专栏如下&#xff1a; C语言刷题解析 C语言系列文章 我的成长经历 感谢阅读&#xff01; 初来乍到&#xff0c;如有错误请指出&#xff0c;感谢&#xff01; 描述 期中考试开始了&am…

基于非下采样小波包分析的滚动轴承故障诊断(MATLAB R2021B)

小波变换具有良好的时频局部化特性和多分辨率特性&#xff0c;可准确定位信号的突变点并可在不同尺度上描述信号的局部细节特征&#xff0c;被广泛应用于信号降噪。但标准正交小波变换不具有平移不变性&#xff0c;采用标准正交小波对信号消噪后&#xff0c;会在脉冲尖峰处产生…

Dubbo 3.x源码(21)—Dubbo服务引用源码(4)

基于Dubbo 3.1&#xff0c;详细介绍了Dubbo服务的发布与引用的源码。 此前我们学习了createInvokerForRemote方法中的Wrapper有哪些以及作用&#xff0c;接下来我们将会的学习真正的本地、应用级别、接口级别的Protocol的引入逻辑&#xff0c;以及创建Proxy服务接口代理对象的逻…

UI学习的案例——照片墙

照片墙案例 在实现照片墙案例之前先讲一下userInteractionEnable这个属性。 首先这个属性属于UIView&#xff0c;这个属性是bool类型&#xff0c;如果为YES的话&#xff0c;这个UIView会接受有关touch和keyboard的相关操作&#xff0c;然后UIView就可以通过相应的一些方法来处…

Hive日志介绍

日志描述 日志路径&#xff1a;Hive相关日志的默认存储路径为“/var/log/Bigdata/hive/角色名”&#xff0c;Hive1相关日志的默认存储路径为“/var/log/Bigdata/hive1/角色名”&#xff0c;以此类推。 HiveServer&#xff1a;“/var/log/Bigdata/hive/hiveserver”&#xff0…

# log.info(“消息发送成功“); 红色报错 解决方案

log.info(“消息发送成功”); 红色报错 解决方案 一、错误描述&#xff1a; 在使用 idea 创建 maven 项目导入 lombok 依赖时&#xff0c;出现 log.info 报红错误&#xff0c;检查导入依赖正确&#xff0c;网络正常&#xff0c;错误依旧。 二、解决方案&#xff1a; 1、在 i…

MATLAB入门知识

目录 原教程链接&#xff1a;数学建模清风老师《MATLAB教程新手入门篇》https://www.bilibili.com/video/BV1dN4y1Q7Kt/ 前言 历史记录 脚本文件&#xff08;.m&#xff09; Matlab帮助系统 注释 ans pi inf无穷大 -inf负无穷大 i j虚数单位 eps浮点相对精度 0/&a…

架构设计-加密解决的基本工具方法

软件工程实施过程中&#xff0c;经常会用到加密解密相关的工具类&#xff0c;整理如下&#xff1a; import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder;import javax.crypto.Cipher; import java.security.*; import java.security.interfaces.RSAPrivateKey; imp…

利用CSS隐藏HTML元素并插入替代内容

在创建一个支持切换阅读模式和答题模式的Anki问答题模板中&#xff0c;我创建了一个支持切换阅读模式和答题模式的问答题模板&#xff0c;该文最终利用JavaScript将Anki输出的向下箭头删除&#xff0c;并插入自定义的提示语。经过进一步测试&#xff0c;发现实现上述功能完全不…

一步一学!如何通过SOLIDWORKS曲面放样绘制花瓶?

SOLIDWORKS中&#xff0c;我们对放样凸台的操作已经非常熟悉。现在&#xff0c;我们将进一步探索曲面菜单栏中的放样成型功能。 1、绘制草图 首先&#xff0c;同普通放样凸台建模相同&#xff0c;绘制放样轮廓及引导线段。 可通过创建基准面布置轮廓&#xff0c;利用穿透选项将…

定个小目标之刷LeetCode热题(13)

今天来看看这道题&#xff0c;介绍两种解法 第一种动态规划&#xff0c;代码如下 class Solution {public int maxSubArray(int[] nums) {int pre 0, maxAns nums[0];for (int x : nums) {// 计算当前最大前缀和pre Math.max(pre x, x);// 更新最大前缀和maxAns Math.ma…