MySQL分区表的使用介绍

来源:未知 责任编辑:责任编辑 发表时间:2015-10-08 14:16 点击:

MySQL使用分区表的好处:
1,可以把一些归类的数据放在一个分区中,可以减少服务器检查数据的数量加快查询。
2,方便维护,通过删除分区来删除老的数据。
3,分区数据可以被分布到不同的物理位置,可以做分布式有效利用多个硬盘驱动器。

MySQL可以建立四种分区类型的分区:
          RANGE 分区:基于属于一个给定连续区间的列值,把多行分配给分区。
·         LIST 分区:类似于按RANGE分区,区别在于LIST分区是基于列值匹配一个离散值集合中的某个值来进行选择。  www.2cto.com  
·         HASH分区:基于用户定义的表达式的返回值来进行选择的分区,该表达式使用将要插入到表中的这些行的列值进行计算。这个函数可以包含MySQL 中有效的、产生非负整数值的任何表达式。
·         KEY 分区:类似于按HASH分区,区别在于KEY分区只支持计算一列或多列,且MySQL 服务器提供其自身的哈希函数。必须有一列或多列包含整数值。
一般用得多的是range分区和list分区。
RANGE分区
这里以一个销售的业务来做测试
销售表有日期/商品/销售额三个字段
测试数据从2010年1月1日至2010年9月31日
以“月”为单位进行分区
初期分区定义
首先需要查看,当前数据库是否支持分区
mysql>SHOW VARIABLES LIKE '%partition%';
+-------------------+-------+
| Variable_name     | Value |
 
 
 
 
 
+-------------------+-------+
| have_partitioning | YES   |
 
+-------------------+-------+
1 row in set (0.03 sec)
创建分区表,按照年月的方式分区。
mysql> CREATE TABLE sale_data (
    ->   sale_date  DATETIME NOT NULL,
 
    ->   sale_item  VARCHAR(2) NOT NULL ,
 
    ->   sale_money DECIMAL(10,2) NOT NULL
 
    -> )  www.2cto.com  
 
    -> PARTITION BY RANGE (YEAR(sale_date)*100+MONTH(sale_date)) (
 
    ->   PARTITION p201001 VALUES LESS THAN (201002),
 
    ->   PARTITION p201002 VALUES LESS THAN (201003),
 
    ->   PARTITION p201003 VALUES LESS THAN (201004),
 
    ->   PARTITION p201004 VALUES LESS THAN (201005),
 
    ->   PARTITION p201005 VALUES LESS THAN (201006),
 
    ->   PARTITION p201006 VALUES LESS THAN (201007),
 
    ->   PARTITION p201007 VALUES LESS THAN (201008),
 
    ->   PARTITION p201008 VALUES LESS THAN (201009),
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码:点击我更换图片
最新评论 更多>>

推荐热点

  • Oracle数据导入MySQL的快捷工具:MySQL Migration Toolkit
  • 简简单单储存过程——循环一个select结果集
  • MySQL Stmt预处理提高效率问题的小研究
  • 用批处理启动MySQL命令行工具
  • MySQL数据库十大优化技巧
  • mysqldump命令——MySQL数据库备份还原
  • Mysql主主复制架构配置
  • mysql-mmm
  • Mysql的Procedure 参数为NULL问题分析
网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
Copyright © 2008-2015 计算机技术学习交流网. 版权所有

豫ICP备11007008号-1