深入了解mysql 5.5分区功能增强_深入了解MySQL 5.5分区功能增强

mysql p="">

221891_0.jpg

图 1 大家还没注意到我MySQL的分区功能也很强了哦

非整数列分区

任何使用过分区的人应该都遇到过不少问题,特别是面对非整数列分区时,MySQL 5.1只能处理整数列分区,如果你想在日期或字符串列上进行分区,你不得不使用函数对其进行转换。

MySQL 5.5中新增了两类分区方法,RANG和LIST分区法,同时在新的函数中增加了一个COLUMNS关键词。我们假设有这样一个表:

CREATE TABLE expenses (

expense_date DATE NOT NULL,

category VARCHAR(30),

amount DECIMAL (10,3)  );

如果你想使用MySQL 5.1中的分区类型,那你必须将类型转换成整数,需要使用一个额外的查找表,到了MySQL 5.5中,你可以不用再进行类型转换了,如:

ALTER TABLE expenses  PARTITION BY LIST COLUMNS (category)  (

PARTITION p01 VALUES IN ( lodging, food),

PARTITION p02 VALUES IN ( flights, ground transportation),

PARTITION p03 VALUES IN ( leisure, customer entertainment),

PARTITION p04 VALUES IN ( communications),

PARTITION p05 VALUES IN ( fees)  );

这样的分区语句除了更加易读外,对数据的组织和管理也非常清晰,上面的例子只对category列进行分区。

在MySQL 5.1中使用分区另一个让人头痛的问题是date类型(即日期列),你不能直接使用它们,必须使用YEAR或TO_DAYS转换这些列,如:

/* 在MySQL 5.1中*/

CREATE TABLE t2

(

dt DATE

)

PARTITION BY RANGE (TO_DAYS(dt))

(

PARTITION p01 VALUES LESS THAN (TO_DAYS(2007-01-01)),

PARTITION p02 VALUES LESS THAN (TO_DAYS(2008-01-01)),

PARTITION p03 VALUES LESS THAN (TO_DAYS(2009-01-01)),

PARTITION p04 VALUES LESS THAN (MAXVALUE));

SHOW CREATE TABLE t2G

*************************** 1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值