mysql正确的日期分区例子

本文通过一个具体的MySQL日期分区示例,展示了如何利用TO_DAYS()函数进行分区,并通过对比查询性能,说明了正确分区对于查询效率的显著提升。在案例中,查询在分区后的表part_date3上仅需4秒,而在未分区表part_date1上则耗时40秒,体现出90%的效率提升。强调了正确使用分区和验证查询优化的重要性。
摘要由CSDN通过智能技术生成

正确的日期分区例子

mysql优化器支持以下两种内置的日期函数进行分区:

TO_DAYS()

YEAR()

看个例子:

CODE:

mysql> CREATE TABLE part_date3

-> ( c1 int default NULL,

-> c2 varchar(30) default NULL,

-> c3 date default NULL) engine=myisam

-> partition by range (to_days(c3))

-> (PARTITION p0 VALUES LESS THAN (to_days(‘1995-01-01’)),

-> PARTITION p1 VALUES LESS THAN (to_days(‘1996-01-01’)) ,

-> PARTITION p2 VALUES LESS THAN (to_days(‘1997-01-01’)) ,

-> PARTITION p3 VALUES LESS THAN (to_days(‘1998-01-01’)) ,

-> PARTITION p4 VALUES LESS THAN (to_days(‘1999-01-01’)) ,

-> PARTITION p5 VALUES LESS THAN (to_days(‘2000-01-01’)) ,

-> PARTITION p6 VALUES LESS THAN (to_days(‘2001-01-01’)) ,

-> PARTITION p7 VALUES LESS THAN (to_days(‘2002-01-01’)) ,

-> PARTITION p8 VALUES LESS THAN (to_days(‘2003-01-01’)) ,

-> PARTITION p9 VALUES LESS THAN (to_days(‘2004-01-01’)) ,

-> PARTITION p10 VALUES LESS THAN (to_days(‘2010-01-01’)),

-> PARTITION p11 VALUES LESS THAN MAXVALUE );

Query OK, 0 rows affected (0.00 sec)

以to_days()函数分区成功,我们分析一下看看:

CODE:

mysql> explain partitions select count(*) from part_date3 where c3> date ‘1995-01-01’ and c3 ‘1995-12-31’ ;

*************************** 1. row ***************************

id: 1

select_type: SIMPLE

table: part_date3

partitions: p1

type: ALL

possible_keys: NULL

key: NULL

key_len: NULL

ref: NULL

rows: 808431

Extra: Using where

1 row in set (0.00 sec)

可以看到,mysql优化器这次不负众望,仅仅在p1分区进行查询。在这种情况下查询,真的能够带来提升查询效率么?下面分别对这次建立的part_date3和之前分区失败的part_date1做一个查询对比:

CODE:

mysql> select count(*) from part_date3 where

-> c3> date ‘1995-01-01’ and c3 ‘1995-12-31’;

±---------+

| count(*) |

±---------+

| 805114 |

±---------+

1 row in set (4.11 sec)

mysql> select count(*) from part_date1 where

-> c3> date ‘1995-01-01’ and c3 ‘1995-12-31’;

±---------+

| count(*) |

±---------+

| 805114 |

±---------+

1 row in set (40.33 sec)

可以看到,分区正确的话query花费时间为4秒,而分区错误则花费时间40秒(相当于没有分区),效率有90%的提升!所以我们千万要正确的使用分区功能,分区后务必用explain验证,这样才能获得真正的性能提升。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值