关于 Mysql 分区问题

2019-08-29 17:17:00 +08:00
 ChenKevin
1.有一张心跳表 tb_heartbeat ( id int, tid varchar(64), hbTime dateTime);
2.保存最近七天的数据,每天凌晨删除七天前的数据
3.创建按星期几的分区(为了不频繁创建和 drop 分区)。
ALTER TABLE tb_heartbeat PARTITION BY RANGE(WEEKDAY(hbTime))(
PARTITION p1 VALUES less than (1),
PARTITION p2 VALUES less than (2),
PARTITION p3 VALUES less than (3),
PARTITION p4 VALUES less than (4),
PARTITION p5 VALUES less than (5),
PARTITION p6 VALUES less than (6),
PARTITION p7 VALUES less than (MAXVALUE)
);
4.但是在删除某一天的数据,它会遍历所有分区。
EXPLAIN PARTITIONS DELETE from tb_heartbeat where hbtime < '2019-08-29 23:59:59' and hbtime > '2019-08-29 00:00:00'
会遍历 partitions:p1,p2,p3,p4,p5,p6,p7
5.这里关于分区裁剪是没效果吗?
谢谢
1368 次点击
所在节点    问与答
0 条回复

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/596281

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX