位置: 编程技术 - 正文
推荐整理分享MySQL分区字段列有必要再单独建索引吗?(mysql分区语句),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:mysql 分区,mysql分区分表实现,mysql分区语句,mysql分区语句,mysql分区分表实现,mysql分区的数据类型,mysql分区语句,mysql数据表分区,内容如对您有帮助,希望把文章链接给更多的朋友!
前言
大家都知道对于分区字段必须是主键的一部分,那么建了复合主键之后,是否需要对分许字段再单独添加一个索引呢?有没有效果?来验证一下,下面话不多说了,来一起看看详细的介绍吧。
1、新建表effect_new(以创建时间按月分区)
2、插入部分数据数据,
3、分析语句
结果为:
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、结论:
虽然表已经根据此字段分区,但这不能等同于索引。分了区,只能说该字段为某个值的记录会在某个分区里面,但不是索引,还要一顿好找。
有时候,主键不等于分区依据列,这时候主键又想建聚集索引的话,那么必须包含分区依据列,搞成复合主键。那么,这种情况下,分区依据列不就有索引了吗?是的,可是它不够快,如果在这个复合索引里面,分区依据列不排在第一位,就不够快,如果查找语句里常常用分区依据列作为过滤条件,就有必要为分区依据列额外单独建立一个索引。
总结
标签: mysql分区语句
本文链接地址:https://www.jiuchutong.com/biancheng/348305.html 转载请保留说明!友情链接: 武汉网站建设