mysql 表分区技术

,是指根据一定规则,将数据库中的一张表分解成多个更小的,容易管理的部分。从逻辑上看,只有一张表,但是底层却是由多个物理分区组成。
   今天,我通过查阅相关资料与动手操作,学习了一下数据库表分区的技术。个人理解,

  分区表的限制因素

  a.一个表最多只能有1024个分区

  b.MySQL5.1中,分区表达式必须是整数,或者返回整数的表达式。在MySQL5.5中提供了非整数表达式分区的支持。

  c.如果分区字段中有主键或者唯一索引的列,那么多有主键列和唯一索引列都必须包含进来。即:分区字段要么不包含主键或者索引列,要么包含全部主键和索引列。

  d.分区表中无法使用外键约束

  e.MySQL的分区适用于一个表的所有数据和索引,不能只对表数据分区而不对索引分区,也不能只对索引分区而不对表分区,也不能只对表的一部分数据分区。


  如何判断当前MySQL是否支持分区

  命令:show variables like ‘%partition%‘

    

   其中 Variable_name 的Value = 1,我测试过了,表示可以正常分区的。我数据库的版本是:

   


    MySQL支持的分区类型有RANGE分区,LIST分区,HASH分区,KEY分区。其中RANGE,LIST,HASH分区等一般使用Int类型,KEY分区使用BLOB,TEXT类型等。

然后采取第二种用法,如图所示:

   

   
    分区成功了,呵呵呵!

  

 有几点注意:
 a. 对于分区s1,表示 1 不管哪种分区类型,,除非两者都没有,否者将会报如下错误。

如果是将注册日期作为分区键,则须要使用日期处理函数转换为整型,例如year(regDate),to_days(regDate),to_seconds(regDate),且只支持这三个函数。

mysql 表分区技术_第1张图片
获取【下载地址】 

你可能感兴趣的:(mysql,表分区技术)