首页 > 数据库 > MySQL 5.5 分区之非整数列分区详解

MySQL 5.5 分区之非整数列分区详解

2012年01月05号
查看评论 发表评论 122次浏览

 非整数列分区

  任何使用过分区的人应该都遇到过不少问题,特别是面对非整数列分区时,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列进行分区。

类别数据库 标签
  1. 目前没有评论
你必需 登陆 才能发表评论.