准备
1.创建如下表结构
data:image/s3,"s3://crabby-images/e5e90/e5e9002992b54e704ddcb07602e45f73f484abf3" alt=""
表结构图
2.添加百万条测试数据,注意数据的分散性
data:image/s3,"s3://crabby-images/0afb9/0afb9658217de34c4f09ff337157338568febf0d" alt=""
测试数据截图
测试
1.创建 account 单列索引
CREATE INDEX account_index ON user_info(account);
1.1 首先测试哪些操作会用到索引
select * from user_info order by account limit 10;
data:image/s3,"s3://crabby-images/58425/58425dca1af38a1a3de7c36136673d31f9fc3744" alt=""
排序使用索引测试
select * from user_info where account = '10701445';
data:image/s3,"s3://crabby-images/507a2/507a263fa05920f66887d378ca3845c8a2b47b5d" alt=""
查询使用索引测试
- 结论
ORDER BY和WHERE操作都会使用到索引,且数据越分散作用越大。
1.2 如何使用索引
select * from user_info order by account limit 10; (使用索引)
select * from user_info order by age, account limit 10; (不使用索引)
select * from user_info where age > 25 and account = '15182615'; (使用索引)
select * from user_info where account = '15182615'; (使用索引)
2.创建 组合索引 account, email
create index account_email_index on user_info(account, email);
2.1 同单列索引一样,ORDER BY 和 SELECT 会使用到组合索引
2.2 如何使用组合索引
select * from user_info order by account, email limit 10; (使用索引)
select * from user_info order by account limit 10; (使用索引)
select * from user_info order by email limit 10; (不使用索引)
select * from user_info where name = '是稍' and account = '15182615'; (使用索引)
select * from user_info where name = '是稍' and email = '2x63dC7y@yahoo.com'; (不使用索引)
网友评论