mysql分区表

分区表
 
分区表的优点:
数据分开存放在不同的文件,可以支持更大的数据文件
在某些特定条件下能提高查询、删除、更新的效率
 
1、range分区表
  mysql> create table mytest(id int,name varchar(20) not null,birthday date,primary key(id,birthday))auto_increment=1 partition by range(year(birthday))( partition p01 values less than (2000), partition p02 values less than (2010), partition p03 values less than maxvalue);
 
 
  练习:创建一个新表,包含学生编号,学生姓名,联系电话、所属院系四个字段,其中院系为5个数字值,分别为
  1、2、3、4、5代表五个不同的院系,要求将表里面的数据按院系分别保存到5个不同的数据文件,创建完成后
  观察数据文件的名称和大小等信息,并插入几条数据
 
2、list分区表
  mysql> create table mytest1(sid int not null,name varchar(20),area varchar(10)) partition by list (sid) (partition p01 values in (1,2), partition p02 values in (3,4),partition p03 values in (5,6));
  注意:要求分区的列必须是整数类型
 
  练习:创建一个包含员工id、员工姓名、员工住址的表,将员工id的尾数为1、4、7的存放到p01分区,2、5、8的
       存放到p02分区,3、6、9存放到p03分区,然后存储id为1-10的10个数据,观察存储情况
 
 
  mysql> create table xixi(id int not null,name varchar(20),addr varchar(10)) partition by list (id%10) (partition p01 values in (1,4,7),partition p02 values in (2,5,8),partition p03 values in (3,6,9));

3、hash分区表
  mysql> create table mytest1(sid int not null,name varchar(20),area varchar(10)) partition by hash (sid) partitions 3;
 
  mysql> create table mytest1(sid int not null,name varchar(20),area varchar(10)) partition by linear hash (sid) partitions 3;
 
4、key分区
  mysql> create table mytest1(sid int not null,name varchar(20),area varchar(10)) partition by key (area) partitions 3;
 
  mysql> create table mytest1(sid int not null,name varchar(20),area varchar(10)) partition by linear key (area) partitions 3;
5、分区管理
 新增分区
 mysql> alter table sinfo add partition (partition gd06 values less than (7));
 mysql> alter table mytest1 partition by key(area) partitions 4;

alter table haha add partition (partition p03 values in (3,6,9));

删除分区
 mysql> alter table sinfo drop partition gd01;
 mysql> alter table mytest1 partition by key(area) partitions 3;
 
 合并分区
 
  mysql> alter table sinfo reorganize partition p03,p04 into (
   -> partition p034 values in (0,3,6,9));

时间: 2024-08-06 03:40:21

mysql分区表的相关文章

MySQL分区表(转)

查看分区情况 SELECT * FROM information_schema.PARTITIONS WHERE table_name='table_name': PARTITION_NAME:分区的名称 PARTITION_METHOD:分区的类型 TABLE_ROWS:分区数据条数 RANGE分区: create table t ( id int) engine=innodb partition by range (id) ( partition p0 values less than (1

MySQL分区表使用方法

原文:MySQL分区表使用方法 1. 确认MySQL服务器是否支持分区表 命令: show plugins; 2. MySQL分区表的特点 在逻辑上为一个表,在物理上存储在多个文件中 HASH分区(HASH) HASH分区的特点 根据MOD(分区键,分区数)的值把数据行存储到表的不同分区中 数据可以平均的分布在各个分区中 HASH分区的键值必须是一个INT类型的值,或是通过函数可以转为INT类型 如何建立HASH分区表 以INT类型字段 customer_id为分区键 CREATE TABLE

MySQL 分区表原理及数据备份转移实战

1.分区表含义 分区表定义指根据可以设置为任意大小的规则,跨文件系统分配单个表的多个部分.实际上,表的不同部分在不同的位置被存储为单独的表.用户所选择的.实现数据分割的规则被称为分区函数,这在MySQL中它可以是模数,或者是简单的匹配一个连续的数值区间或数值列表,或者是一个内部HASH函数,或一个线性HASH函数. 分表与分区的区别在于:分区从逻辑上来讲只有一张表,而分表则是将一张表分解成多张表. 2.分区表优点 1)分区表更容易维护.对于那些已经失去保存意义的数据,通常可以通过删除与那些数据有

MySQL分区表姿势

大部分内容整理自姜承尧的innodb存储引擎2学习笔记. 分区: 分区的功能不是在存储引擎层实现的.因此不只是InnoDB才支持分区.MyISAM.NDB都支持分区操作. 分区的过程是将一个表或者索引分解为多个更小.更可管理的部分.从逻辑上将,只有一个表或者索引,但是在物理上这个表或索引可能由数十个物理分区组成. 每个分区都是独立的对象,可以独自处理,也可以作为一个更大对象的一部分进行处理. MySQL只支持水平分区,不支持垂直分区. 水平分区:将同一表中不同行的记录分配到不同的物理文件中. 垂

MySQL分区表管理

RANGE,LIST分区管理 1:为未分区表创建分区 ALTER TABLE trb3 PARTITION BY KEY(id) PARTITIONS 2; 2:删除某个分区的数据 ALTER TABLE tr DROP PARTITION p2; 3:为分区表添加一个分区 ALTER TABLE members ADD PARTITION (PARTITION p3 VALUES LESS THAN (2000)); ALTER TABLE tt ADD PARTITION (PARTITIO

MySQL 分区表

今天统计数据的时候发现一张表使用了表分区,借此机会记录一下. 1. 什么是表分区? 表分区,是指根据一定规则,将数据库中的一张表分解成多个更小的,容易管理的部分.从逻辑上看,只有一张表,但是底层却是由多个物理分区组成. 2. 表分区与分表的区别 分表:指的是通过一定规则,将一张表分解成多张不同的表.比如将用户订单记录根据时间成多个表. 分表与分区的区别在于:分区从逻辑上来讲只有一张表,而分表则是将一张表分解成多张表. 3. 表分区有什么好处? 1)分区表的数据可以分布在不同的物理设备上,从而高效

MySQL分区表的管理~2

一.维护分区 对于表的维护,我们一般有如下几种方式: CHECK TABLE, OPTIMIZE TABLE, ANALYZE TABLE和REPAIR TABLE. 而这几种方式,对于分区同样适用.下面,我们一一阐述各种的作用. 1. Rebuilding partitions 重建分区,它相当于先删除分区中的数据,然后重新插入.这个主要是用于分区的碎片整理. 譬如: ALTER TABLE t1 REBUILD PARTITION p0, p1; 2. Optimizing partitio

MySQL 分区表原理及使用详解

今天统计数据的时候发现一张表使用了表分区,借此机会记录一下. 1. 什么是表分区? 表分区,是指根据一定规则,将数据库中的一张表分解成多个更小的,容易管理的部分.从逻辑上看,只有一张表,但是底层却是由多个物理分区组成. 2. 表分区与分表的区别 分表:指的是通过一定规则,将一张表分解成多张不同的表.比如将用户订单记录根据时间成多个表. 分表与分区的区别在于:分区从逻辑上来讲只有一张表,而分表则是将一张表分解成多张表. 3. 表分区有什么好处? 1)分区表的数据可以分布在不同的物理设备上,从而高效

mysql 分区表详解

项目中要一张库表实现 list分区.并且支持多种数据库. oracle 很顺利,只是mysql 听说5.1版本就已经支持了, 可是试了很多个版本,都不行,后来查到原因是要5.5 以上版本 分区才支持 varchar, 可是试到 5.6 都一直报错: "VALUES value for partition 'P_XX' must have type INT" 后来才发现.原来没有查对资料,走了弯路.是LIST COLUMNS才支持 varchar类型的分区字段. mysql 官方文档