当前位置导航:炫浪网>>网络学院>>操作系统>>新闻资讯

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

图 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 t2\G
  *************************** 1. row ***************************
        
Table: t2  Create Table:
CREATE TABLE `t2` (
    `dt` date
DEFAULT NULL
)
ENGINE
=MyISAM DEFAULT CHARSET=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) */

炫浪网络学院

相关内容
赞助商链接