sql中索引的使用分析

主要学习和记录sql中索引的使用

1.批量在库里插入了27W条数据

CREATE DEFINER=`root`@`%` PROCEDURE `批量插入`()

BEGIN

#Routine body goes here...

DECLARE i int;

SET i=1;

WHILE (i<100000) DO

insert into kucun_info (shop_name,shop_code,shop_price,shop_inventory,shop_source) VALUES(972,875,3445,37655,654);

set i = i+1;

END WHILE;

END

2.EXPLAIN +sql语句的分析

EXPLAIN SELECT * FROM kucun_info WHERE kucunid = 3 -- const级别

EXPLAIN SELECT * FROM kucun_info WHERE shop_code = "XJ_001"

EXPLAIN SELECT * FROM kucun_info WHERE shop_name = "香蕉001"-- ref 级别

3.分析

-- 27W条数据

SET profiling = 1;

SELECT * FROM kucun_info WHERE shop_code = "XJ_001" -- 没加索引 0.086S

SELECT * FROM kucun_info WHERE shop_name = "香蕉001"-- 添加索引 0.015S

SELECT kucunid FROM kucun_info WHERE shop_code = "PT_001"

SELECT * FROM kucun_info WHERE shop_name = "葡萄001"

SHOW PROFILES; -- 查看执行sql语句的时间

可以分析出:27W条数据 加索引能快5倍

相关推荐
码农水水几秒前
小红书Java面试被问:mTLS(双向TLS)的证书验证和握手过程
java·开发语言·数据库·redis·python·面试·开源
dyyx1112 分钟前
Python GUI开发:Tkinter入门教程
jvm·数据库·python
王大傻09287 分钟前
sqlmap的简要介绍
sql·网络安全
2401_836121609 分钟前
更优雅的测试:Pytest框架入门
jvm·数据库·python
我真的是大笨蛋12 分钟前
MySQL临时表深度解析
java·数据库·sql·mysql·缓存·性能优化
九皇叔叔13 分钟前
【02】微服务系列 之 初始化工程
java·数据库·微服务
你想考研啊23 分钟前
win11配置maven
java·数据库·maven
南屿欣风26 分钟前
MySQL Binlog 数据恢复实战
数据库·mysql
DomDanrtsey32 分钟前
oracle查询某数据库用户下哪些表的索引没有被使用到?
数据库·oracle
独处东汉39 分钟前
freertos开发空气检测仪之输入子系统按键驱动测试
android·java·数据库