索引

-- 前缀索引和索引选择性

-- 构建demo表数据
drop TABLE city_demo;
create table city_demo(city varchar(50) not null) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
insert into city_demo(city) select name from hz_china_area;
select count() from city_demo;
-- 找到最常见的城市列表
select count(
) as cnt, city from city_demo group by city order by cnt desc limit 11;
-- 找到最频繁出现的前缀
select count(*) as cnt, left(city, 3) as pref from city_demo group by pref order by cnt desc limit 10;

-- 计算完整列的选择性
select count(distinct city)/count(*) from city_demo;

select count(distinct left(city,3))/count() as sel3,
count(distinct left(city,4))/count(
) as sel4,
count(distinct left(city,5))/count() as sel5,
count(distinct left(city,6))/count(
) as sel6,
count(distinct left(city,7))/count(*) as sel7
from city_demo;

-- 创建前缀索引. 前缀索引不能做order by和group by, 也不能做覆盖扫描
-- 可以在衣柜很长的16进制字符串上创建索引. 比如长度8,可以显著的提升性能.
alter table city_demo add key (city(7));

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • B-Tree索引 适用于全键型、键值范围、键前缀查找 全值匹配 匹配最左前缀 匹配列前缀 匹配范围值 精确匹配某一...
    低调的小玩偶阅读 1,391评论 0 0
  • 高效地选择和使用索引有很多种方式, 其中有些是针对特殊案例的优化方法, 有些则是针对特定行为的优化. 1 独立的列...
    沪上最强亚巴顿阅读 5,030评论 1 12
  • MySQL索引总结 索引原理 索引的优缺点 优点 索引大大减小了服务器需要扫描的数据量 索引可以帮助服务器避免排序...
    直觉00_57阅读 1,211评论 0 0
  • 索引原理 索引的优缺点 优点索引大大减小了服务器需要扫描的数据量索引可以帮助服务器避免排序和临时表索引可以将随机I...
    我爱张智容阅读 3,624评论 0 0
  • 对于数据库的优化主要包括三个部分:查询优化、索引优化和字段类型优化,其中,索引优化则是数据库优化的重中之重。一个查...
    charming_coder阅读 9,835评论 1 18

友情链接更多精彩内容