位置: 编程技术 - 正文

MySQL分区字段列有必要再单独建索引吗?(mysql分区语句)

编辑:rootadmin

推荐整理分享MySQL分区字段列有必要再单独建索引吗?(mysql分区语句),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql 分区,mysql分区分表实现,mysql分区语句,mysql分区语句,mysql分区分表实现,mysql分区的数据类型,mysql分区语句,mysql数据表分区,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

大家都知道对于分区字段必须是主键的一部分,那么建了复合主键之后,是否需要对分许字段再单独添加一个索引呢?有没有效果?来验证一下,下面话不多说了,来一起看看详细的介绍吧。

1、新建表effect_new(以创建时间按月分区)

2、插入部分数据数据,

3、分析语句

结果为:

MySQL分区字段列有必要再单独建索引吗?(mysql分区语句)

id select_type table partitions tpye possible_keys key key_len ref rows filtered extra 1 SIMPLE effect_new p8 ALL null null null null Using where

4、给表effect_new添加索引idx_ctime

5、分析添加索引后的执行计划

结果为:

id select_type table partitions tpye possible_keys key key_len ref rows filtered extra 1 SIMPLE effect_new p8 ref idx_ctime idx_ctime 5 const null

6、结论:

虽然表已经根据此字段分区,但这不能等同于索引。分了区,只能说该字段为某个值的记录会在某个分区里面,但不是索引,还要一顿好找。

有时候,主键不等于分区依据列,这时候主键又想建聚集索引的话,那么必须包含分区依据列,搞成复合主键。那么,这种情况下,分区依据列不就有索引了吗?是的,可是它不够快,如果在这个复合索引里面,分区依据列不排在第一位,就不够快,如果查找语句里常常用分区依据列作为过滤条件,就有必要为分区依据列额外单独建立一个索引。

总结

本文链接地址:https://www.jiuchutong.com/biancheng/348305.html 转载请保留说明!

上一篇:Ubuntu下MySQL安装及配置远程登录教程

下一篇:Windows下Mysql启动报1067的解决方法(windows下启动mysql的命令是什么)

免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

鄂ICP备2023003026号

网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

友情链接: 武汉网站建设 电脑维修 湖南楚通运网络