设为首页 加入收藏

TOP

深入了解MySQL 5.5分区功能增强
2014-11-24 02:44:55 来源: 作者: 【 】 浏览:2
Tags:深入 了解 MySQL 5.5分区 功能 增强

mysql p="">

\

图 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
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇ORACLE日期时间函数大全 下一篇11gR2 Redundant Interconnet and..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: