当前位置:首页 >知识 >深入了解MySQL 5.5分区功能增强 虽然已经报道了很多增强功能

深入了解MySQL 5.5分区功能增强 虽然已经报道了很多增强功能

2024-06-30 20:45:00 [百科] 来源:避面尹邢网

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

原创 作者:黄永兵 译 数据库 MySQL 数据库运维 Oracle在并购Sun后对于MySQL的深入态度令人寻味。在新发布的分区MySQL 5.5中带来了许多增强的功能,在这篇文章中,增强我们将解释一下MySQL 5.5分区功能的深入增强特性。

【51CTO经典译文】MySQL 5.5的分区发布带来了许多增强的功能,虽然已经报道了很多增强功能,增强如半同步复制,深入但大家却忽略了分区方面的分区增强,有时甚至还对其真正意义产生了误解,增强在这篇文章中,深入我们希望解释一下这些很酷的分区增强,特别是增强我们大多数人还没有完全理解的地方。51CTO向您推荐《MySQL数据库入门与精通教程》。深入

MySQL 5.5分区增强

深入了解MySQL 5.5分区功能增强 虽然已经报道了很多增强功能

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

深入了解MySQL 5.5分区功能增强 虽然已经报道了很多增强功能

非整数列分区

深入了解MySQL 5.5分区功能增强 虽然已经报道了很多增强功能

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

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

  1. CREATE TABLE expenses (  
  2.   expense_date DATE NOT NULL,  
  3.   category VARCHAR(30),  
  4.   amount DECIMAL (10,3)  
  5. ); 

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

 

  1. ALTER TABLE expenses  
  2. PARTITION BY LIST COLUMNS (category)  
  3. (  
  4.   PARTITION p01 VALUES IN ( 'lodging', 'food'),  
  5.   PARTITION p02 VALUES IN ( 'flights', 'ground transportation'),  
  6.   PARTITION p03 VALUES IN ( 'leisure', 'customer entertainment'),  
  7.   PARTITION p04 VALUES IN ( 'communications'),  
  8.   PARTITION p05 VALUES IN ( 'fees')  
  9. ); 

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

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

  1. /* 在MySQL 5.1中*/  
  2. CREATE TABLE t2  
  3. (  
  4.   dt DATE 
  5. )  
  6. PARTITION BY RANGE (TO_DAYS(dt))  
  7. (  
  8.   PARTITION p01 VALUES LESS THAN (TO_DAYS('2007-01-01')),  
  9.   PARTITION p02 VALUES LESS THAN (TO_DAYS('2008-01-01')),  
  10.   PARTITION p03 VALUES LESS THAN (TO_DAYS('2009-01-01')),  
  11.   PARTITION p04 VALUES LESS THAN (MAXVALUE));  
  12.  
  13. SHOW CREATE TABLE t2 \G  
  14. (责任编辑:探索)

    推荐文章
    热点阅读