MySql性能调优02-[索引优化]

索引优化

MySQL优化


  • 测试用的表和数据
sql 复制代码
DROP TABLE IF EXISTS `employees`;
CREATE TABLE `employees`  (
  `id` int NOT NULL AUTO_INCREMENT COMMENT '主键',
  `name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '姓名',
  `age` int NULL DEFAULT NULL COMMENT '年龄',
  `position` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '职位',
  `hire_time` datetime NULL DEFAULT NULL COMMENT '入职时间',
  `remark` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '备注',
  `salary` decimal(10, 2) NULL DEFAULT NULL COMMENT '薪水',
  PRIMARY KEY (`id`) USING BTREE,
  INDEX `idx_name_age_position`(`name`, `age`, `position`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 11 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of employees
-- ----------------------------
INSERT INTO `employees` VALUES (1, 'John Doe', 25, 'Manager', '2024-07-12 12:14:28', '撒嘎嘎', 5000.00);
INSERT INTO `employees` VALUES (2, 'Jane Smith', 56, 'Engineer', '2024-07-02 12:14:31', '对对对', 4500.00);
INSERT INTO `employees` VALUES (3, 'Bob Johnson', 66, 'Analyst', '2024-06-12 12:14:36', '大概', 4000.00);
INSERT INTO `employees` VALUES (4, 'Alice Brown', 77, 'Marketing Specialist', '2024-07-20 12:14:42', '撒嘎嘎', 3500.00);
INSERT INTO `employees` VALUES (5, 'Mike Davis', 88, 'Sales Representative', '2024-07-28 12:14:47', '谁大纲', 3000.00);
INSERT INTO `employees` VALUES (6, 'Sarah Harris', 99, 'HR Representative', '2024-07-19 12:14:53', '撒呃呃我', 2500.00);
INSERT INTO `employees` VALUES (7, 'Alex Thompson', 102, 'Technician', '2024-08-17 12:14:57', '呵呵呵', 2200.00);
INSERT INTO `employees` VALUES (8, 'Emily Davis', 103, 'Intern', '2024-09-01 12:15:01', '规范国家', 2000.00);
INSERT INTO `employees` VALUES (9, 'David Lee', 56, 'Contractor', '2024-07-08 12:15:09', '一体同', 2500.00);
INSERT INTO `employees` VALUES (10, 'Olivia Martinez', 55, ' Temp', '2024-08-22 12:15:49', '其二切换', 2250.00);

SET FOREIGN_KEY_CHECKS = 1;

索引优化-全值匹配

要查询的列都在联合索引中,这样子就没有回表

索引优化-最左前缀原则

不符合最左前缀原则,索引失效

索引优化-索引列上少计算

索引列进行计算会让索引失去有序性(无法进行二分查找)

索引优化-范围后面全失效

索引优化-覆盖索引不写星

索引优化-不等空值还有or,索引失效要少用

索引优化-like百分写最右

使用前模糊,%xxx会导致索引失效

索引优化-引号不可丢

字符串不加单引号也会导致索引失效(本质是索引进行了类型转换导致索引无序)

索引优化-范围查询优化


索引优化-总结

相关推荐
6 分钟前
达梦数据库-事务
数据库·达梦数据库·dm
子春一27 分钟前
Flutter 与原生平台深度集成:打通 iOS 与 Android 的最后一公里
android·flutter·ios
网硕互联的小客服1 小时前
MYSQL数据库和MSSQL数据库有什么区别?分别适用于什么脚本程序?
数据库·mysql·sqlserver
小邓   ༽1 小时前
全场景Android测试:API、工具与案例,从TestCase到Mock类应用指南
android·android 测试·android 组件测试·mock 类·测试 api 应用·组件测试核心
weixin_462446231 小时前
【原创实践】python 获取节假日列表 并保存为excel
数据库·python·excel
计算机毕设匠心工作室2 小时前
【python大数据毕设实战】全球大学排名数据可视化分析系统、Hadoop、计算机毕业设计、包括数据爬取、数据分析、数据可视化、机器学习、实战教学
后端·python·mysql
千寻技术帮2 小时前
10413_基于Springboot的智慧养老院管理系统
spring boot·mysql·源码·安装·文档·ppt·养老院
RPA 机器人就找八爪鱼2 小时前
RPA 赋能银行数字化转型:四大核心应用场景深度解析
数据库·人工智能·rpa
掂掂三生有幸2 小时前
使用openGauss搭建一个监狱管理系统
数据库