【IT168 文档】MySQL 5.5的发布带来了许多增强的功能,虽然已经报道了很多增强功能,如半同步复制,但大家却忽略了分区方面的增强,有时甚至还对其真正意义产生了误解,在这篇文章中,我们希望解释一下这些很酷的增强,特别是我们大多数人还没有完全理解的地方。
图 1 大家还没注意到我MySQL的分区功能也很强了哦
非整数列分区
任何使用过分区的人应该都遇到过不少问题,特别是面对非整数列分区时,MySQL 5.1只能处理整数列分区,如果你想在日期或字符串列上进行分区,你不得不使用函数对其进行转换。
MySQL 5.5中新增了两类分区方法,RANG和LIST分区法,同时在新的函数中增加了一个COLUMNS关键词。我们假设有这样一个表:
CREATETABLEexpenses (
expense_date DATENOTNULL,
categoryVARCHAR(30),
amountDECIMAL(10,3) );
如果你想使用MySQL 5.1中的分区类型,那你必须将类型转换成整数,需要使用一个额外的查找表,到了MySQL 5.5中,你可以不用再进行类型转换了,如:
ALTERTABLEexpenses PARTITIONBYLIST COLUMNS (category) (
PARTITION p01VALUESIN('lodging','food'),
PARTITION p02VALUESIN('flights','ground transportation'),
PARTITION p03VALUESIN('leisure','customer entertainment'),
PARTITION p04VALUESIN('communications'),
PARTITION p05VALUESIN('fees') );
这样的分区语句除了更加易读外,对数据的组织和管理也非常清晰,上面的例子只对category列进行分区。
在MySQL 5.1中使用分区另一个让人头痛的问题是date类型(即日期列),你不能直接使用它们,必须使用YEAR或TO_DAYS转换这些列,如:
/*在MySQL 5.1中*/CREATETABLEt2
(
dt DATE
)
PARTITIONBYRANGE (TO_DAYS(dt))
(
PARTITION p01VALUESLESS THAN (TO_DAYS('2007-01-01')),
PARTITION p02VALUESLESS THAN (TO_DAYS('2008-01-01')),
PARTITION p03VALUESLESS THAN (TO_DAYS('2009-01-01')),
PARTITION p04VALUESLESS THAN (MAXVALUE));
SHOWCREATETABLEt2\G
***************************1. row***************************Table: t2CreateTable:CREATETABLE`t2` (
`dt` dateDEFAULTNULL)
ENGINE=MyISAMDEFAULTCHARSET=latin1
/*!50100 PARTITION BY RANGE (TO_DAYS(dt))
(PARTITION p01 VALUES LESS THAN (733042) ENGINE = MyISAM,
PARTITION p02 VALUES LESS THAN (733407) ENGINE = MyISAM,
PARTITION p03 VALUES LESS THAN (733773) ENGINE = MyISAM,
PARTITION p04 VALUES LESS THAN MAXVALUE ENGINE = MyISAM) */