列表分区(List分区)

这里假设表中有一个sale_item_type 字段,数据类型为INT 型

当sale_item_type 为1,3,5的时候,作为一个分区

当sale_item_type 为2,4,6的时候,作为另一个分区

当sale_item_type 为7,8的时候,作为最后一个分区

初期分区定义

mysql> CREATE TABLE sale_data2 (

->   sale_date  DATETIME NOT NULL,

->   sale_item_type  INT NOT NULL ,

->   sale_money DECIMAL(10,2) NOT NULL

-> )

-> PARTITION BY LIST (sale_item_type) (

->   PARTITION pFoods VALUES IN (1,3,5),

->   PARTITION pSmoke VALUES IN (2,4,6),

->   PARTITION pDrink VALUES IN (7,8)

-> );

Query OK, 0 rows affected (0.11 sec)

 

核对结果

mysql> SHOW CREATE TABLE sale_data2\G

*************************** 1. row ********************

Table: sale_data2

Create Table: CREATE TABLE `sale_data2` (

`sale_date` datetime NOT NULL,

`sale_item_type` int(11) NOT NULL,

`sale_money` decimal(10,2) NOT NULL

) ENGINE=InnoDB DEFAULT CHARSET=latin1

/*!50100 PARTITION BY LIST (sale_item_type)

(PARTITION pFoods VALUES IN (1,3,5) ENGINE = InnoDB,

PARTITION pSmoke VALUES IN (2,4,6) ENGINE = InnoDB,

PARTITION pDrink VALUES IN (7,8) ENGINE = InnoDB) */

1 row in set (0.00 sec)

新增分区

mysql> ALTER TABLE sale_data2

->   ADD PARTITION (PARTITION pOther VALUES IN (9, 10));

Query OK, 0 rows affected (0.23 sec)

Records: 0  Duplicates: 0  Warnings: 0

核对结果

mysql> SHOW CREATE TABLE sale_data2\G

*************************** 1. row ***************************

Table: sale_data2

Create Table: CREATE TABLE `sale_data2` (

`sale_date` datetime NOT NULL,

`sale_item_type` int(11) NOT NULL,

`sale_money` decimal(10,2) NOT NULL

) ENGINE=InnoDB DEFAULT CHARSET=latin1

/*!50100 PARTITION BY LIST (sale_item_type)

(PARTITION pFoods VALUES IN (1,3,5) ENGINE = InnoDB,

PARTITION pSmoke VALUES IN (2,4,6) ENGINE = InnoDB,

PARTITION pDrink VALUES IN (7,8) ENGINE = InnoDB,

PARTITION pOther VALUES IN (9,10) ENGINE = InnoDB) */

1 row in set (0.00 sec)

删除分区

mysql> ALTER TABLE sale_data2

->   DROP PARTITION pOther;

Query OK, 0 rows affected (0.34 sec)

Records: 0  Duplicates: 0  Warnings: 0

核对结果

mysql> SHOW CREATE TABLE sale_data2\G

*************************** 1. row ***************************

Table: sale_data2

Create Table: CREATE TABLE `sale_data2` (

`sale_date` datetime NOT NULL,

`sale_item_type` int(11) NOT NULL,

`sale_money` decimal(10,2) NOT NULL

) ENGINE=InnoDB DEFAULT CHARSET=latin1

/*!50100 PARTITION BY LIST (sale_item_type)

(PARTITION pFoods VALUES IN (1,3,5) ENGINE = InnoDB,

PARTITION pSmoke VALUES IN (2,4,6) ENGINE = InnoDB,

PARTITION pDrink VALUES IN (7,8) ENGINE = InnoDB) */

1 row in set (0.00 sec)

分区的拆分

下面的SQL将pDrink 拆分为pBeer 与pCola

mysql> ALTER TABLE sale_data2 REORGANIZE PARTITION pDrink INTO (

->     PARTITION pBeer VALUES IN (7),

->     PARTITION pCola VALUES IN (8)

-> );

Query OK, 0 rows affected (0.39 sec)

Records: 0  Duplicates: 0  Warnings: 0

核对结果

mysql> SHOW CREATE TABLE sale_data2\G

*************************** 1. row ***************************

Table: sale_data2

Create Table: CREATE TABLE `sale_data2` (

`sale_date` datetime NOT NULL,

`sale_item_type` int(11) NOT NULL,

`sale_money` decimal(10,2) NOT NULL

) ENGINE=InnoDB DEFAULT CHARSET=latin1

/*!50100 PARTITION BY LIST (sale_item_type)

(PARTITION pFoods VALUES IN (1,3,5) ENGINE = InnoDB,

PARTITION pSmoke VALUES IN (2,4,6) ENGINE = InnoDB,

PARTITION pBeer VALUES IN (7) ENGINE = InnoDB,

PARTITION pCola VALUES IN (8) ENGINE = InnoDB) */

1 row in set (0.00 sec)

分区的合并

下面的SQL,将pBeer,pCola合并到pDrink

mysql> ALTER TABLE sale_data2

->   REORGANIZE PARTITION pBeer,pCola INTO (

->     PARTITION pDrink VALUES IN (7,8)

-> );

Query OK, 0 rows affected (0.36 sec)

Records: 0  Duplicates: 0  Warnings: 0

核对结果

mysql> SHOW CREATE TABLE sale_data2\G

*************************** 1. row ***********************

Table: sale_data2

Create Table: CREATE TABLE `sale_data2` (

`sale_date` datetime NOT NULL,

`sale_item_type` int(11) NOT NULL,

`sale_money` decimal(10,2) NOT NULL

) ENGINE=InnoDB DEFAULT CHARSET=latin1

/*!50100 PARTITION BY LIST (sale_item_type)

(PARTITION pFoods VALUES IN (1,3,5) ENGINE = InnoDB,

PARTITION pSmoke VALUES IN (2,4,6) ENGINE = InnoDB,

PARTITION pDrink VALUES IN (7,8) ENGINE = InnoDB) */

1 row in set (0.00 sec)

MySQL分区表例子——List分区的更多相关文章

  1. mysql分区表之一:分区原理和优缺点【转】

    1.分区表的原理 分区表是由多个相关的底层表实现,这些底层表也是由句柄对象表示,所以我们也可以直接访问各个分区,存储引擎管理分区的各个底层表和管理普通表一样(所有的底层表都必须使用相同的存储引擎),分 ...

  2. MySQL 分区表,为什么分区键必须是主键的一部分?

    随着业务的不断发展,数据库中的数据会越来越多,相应地,单表的数据量也会越到越大,大到一个临界值,单表的查询性能就会下降. 这个临界值,并不能一概而论,它与硬件能力.具体业务有关. 虽然在很多 MySQ ...

  3. Mysql --分区表(7)Key分区

    Key分区 按照Key进行分区非常类似于按照Hash进行分区,只不过Hash分区允许使用用户自定义的表达式,而Key分区不允许使用用户自定义的表达式,需要使用MySQL服务器提供的HASH函数;同时H ...

  4. Mysql --分区表(6)Hash分区

    HASH分区 HASH分区主要用来分散热点读,确保数据在预先确定个数的分区中尽可能平均分布.对一个表执行HASH分区时,MySQL会对分区键应用一个散列函数,以此确定数据应当放在N个分区中的哪个分区 ...

  5. Mysql --分区表(5)Columns分区

    COLUMNS分区 COLUMNS分区是RANGE和LIST分区的变种.COLUMNS分区支持多列作为分区键进行分区 RANGE COLUNMS分区和LIST COLUMNS都支持非INT型列作为分区 ...

  6. mysql分区表之二:MySQL的表的四种分区类型介绍

    一.什么是表分区 通俗地讲表分区是将一大表,根据条件分割成若干个小表.mysql5.1开始支持数据表分区了.如:某用户表的记录超过了600万条,那么就可以根据入库日期将表分区,也可以根据所在地将表分区 ...

  7. MySQL 分区表

    转载自MySQL 分区表 今天统计数据的时候发现一张表使用了表分区,借此机会记录一下. 1. 什么是表分区? 表分区,是指根据一定规则,将数据库中的一张表分解成多个更小的,容易管理的部分.从逻辑上看, ...

  8. Mysql分表和分区的区别、分库分表介绍与区别

    分表和分区的区别: 一,什么是mysql分表,分区 什么是分表,从表面意思上看呢,就是把一张表分成N多个小表,具体请看:mysql分表的3种方法 什么是分区,分区呢就是把一张表的数据分成N多个区块,这 ...

  9. MySQL分区表

    当数据库数据量涨到一定数量时,性能就成为我们不能不关注的问题,如何优化呢? 常用的方式不外乎那么几种: 1.分表,即把一个很大的表达数据分到几个表中,这样每个表数据都不多. 优点:提高并发量,减小锁的 ...

随机推荐

  1. bzoj3998 [TJOI2015]弦论(SAM)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3998 [题意] 询问排名第k的子串是谁,0代表相同子串不同位置算作相同,1代表相同子串 ...

  2. codeforce 621C Wet Shark and Flowers

    题意:输入个n和质数p,n个区间,每个区间可以等概率的任选一个数,如果选的这个区间和它下个区间选的数的积是p的倍数的话(n的下个是1),就挣2000,问挣的期望 思路:整体的期望可以分成每对之间的期望 ...

  3. 动态加载JS脚本的4种方法

    实现OPOA(One Page One Application)时,必须使用动态加载js. 也就是在用户选择某个菜单项后,再动态加载对应的全部js到客户端. 动态加载js的情况很多啊,比如解决ajax ...

  4. HW2.1

    import java.util.Scanner; public class Solution { public static void main(String[] args) { Scanner i ...

  5. boj1267 Infinite’s Cave 树形dp + 背包

    题目链接:http://acm.bupt.edu.cn/onlinejudge/newoj/showProblem/show_problem.php?problem_id=1267         / ...

  6. Centos kvm桥接

    新建一个ifcfg-br0文件: DEVICE=br0TYPE=BridgeBOOTPROTO=staticBROADCAST=10.1.255.255IPADDR=10.1.29.3NETMASK= ...

  7. [MySQL]快速解决"is marked as crashed and should be repaired"故障

    具体报错如下: Table '.\Tablename\posts' is marked as crashed and should be repaired 提示说论坛的帖子表posts被标记有问题,需 ...

  8. php的fread函数的一个巨大的坑

    先看看fread的manual,如下: http://php.net/manual/en/function.fread.php fread() reads up to length bytes fro ...

  9. C#下的 Emgu CV

    Emgu CV下载地址 http://sourceforge.net/projects/emgucv/files/ 找最新的下就行了,傻瓜式安装,选择目录后自动完成安装,然后提示安装VS2008和VS ...

  10. Android应用换肤总结

    换肤,我们都很熟悉,像XP的主题,塞班的主题.看过国外的一些技术博客,就会发现国内和国外对软件的,或者说移动开发的软件的需求的不同.国外用户注重社交.邮件等功能,国内用户则重视音乐.小说.皮肤等功能, ...