MySQL分区表例子——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分区的更多相关文章
- mysql分区表之一:分区原理和优缺点【转】
1.分区表的原理 分区表是由多个相关的底层表实现,这些底层表也是由句柄对象表示,所以我们也可以直接访问各个分区,存储引擎管理分区的各个底层表和管理普通表一样(所有的底层表都必须使用相同的存储引擎),分 ...
- MySQL 分区表,为什么分区键必须是主键的一部分?
随着业务的不断发展,数据库中的数据会越来越多,相应地,单表的数据量也会越到越大,大到一个临界值,单表的查询性能就会下降. 这个临界值,并不能一概而论,它与硬件能力.具体业务有关. 虽然在很多 MySQ ...
- Mysql --分区表(7)Key分区
Key分区 按照Key进行分区非常类似于按照Hash进行分区,只不过Hash分区允许使用用户自定义的表达式,而Key分区不允许使用用户自定义的表达式,需要使用MySQL服务器提供的HASH函数;同时H ...
- Mysql --分区表(6)Hash分区
HASH分区 HASH分区主要用来分散热点读,确保数据在预先确定个数的分区中尽可能平均分布.对一个表执行HASH分区时,MySQL会对分区键应用一个散列函数,以此确定数据应当放在N个分区中的哪个分区 ...
- Mysql --分区表(5)Columns分区
COLUMNS分区 COLUMNS分区是RANGE和LIST分区的变种.COLUMNS分区支持多列作为分区键进行分区 RANGE COLUNMS分区和LIST COLUMNS都支持非INT型列作为分区 ...
- mysql分区表之二:MySQL的表的四种分区类型介绍
一.什么是表分区 通俗地讲表分区是将一大表,根据条件分割成若干个小表.mysql5.1开始支持数据表分区了.如:某用户表的记录超过了600万条,那么就可以根据入库日期将表分区,也可以根据所在地将表分区 ...
- MySQL 分区表
转载自MySQL 分区表 今天统计数据的时候发现一张表使用了表分区,借此机会记录一下. 1. 什么是表分区? 表分区,是指根据一定规则,将数据库中的一张表分解成多个更小的,容易管理的部分.从逻辑上看, ...
- Mysql分表和分区的区别、分库分表介绍与区别
分表和分区的区别: 一,什么是mysql分表,分区 什么是分表,从表面意思上看呢,就是把一张表分成N多个小表,具体请看:mysql分表的3种方法 什么是分区,分区呢就是把一张表的数据分成N多个区块,这 ...
- MySQL分区表
当数据库数据量涨到一定数量时,性能就成为我们不能不关注的问题,如何优化呢? 常用的方式不外乎那么几种: 1.分表,即把一个很大的表达数据分到几个表中,这样每个表数据都不多. 优点:提高并发量,减小锁的 ...
随机推荐
- html input设置为只读属性
有两种方式可以实现input的只读效果:disabled 和 readonly. 自然两种出来的效果都是只能读取不能编辑,可是两者有很大不同. Disabled说明该input无效,及其value不会 ...
- Linux 下svn恢复到某一版本
经常由于坑爹的需求,功能要切回到之前的某一个版本.有两种方法可以实现: 方法1: 用svn merge 1) 先 svn up,保证更新到最新的版本,如20: 2) 然后用 svn log ,查看历史 ...
- HW3.10
public class Solution { public static void main(String[] args) { int number1 = (int)(Math.random() * ...
- POJ1873 - Balance(01背包)
题目大意 现有一个天平,它有C个挂钩和G个砝码,问有多少种方法可以使得天平平衡(砝码必须用完) 题解 其实就是让背包容量为0的方法有多少种方法,但是这样的话背包容量会出现负数,所以可以平移一下,背包容 ...
- java动态编程库,利用动态编程打印运行时调用全景(函数调用关系链)
如果是一般java程序,不追求性能极致,想使用方便,推荐使用 Javassist 库. 如果是android程序,或者一般java程序欲追求性能极限,推荐使用 asm for java 及 asmde ...
- CM5(Cloudera Manager 5) + CDH5(Cloudera's Distribution Including Apache Hadoop 5)的安装详细文档
参考 :http://www.aboutyun.com/thread-9219-1-1.html Cloudera Manager5及CDH5在线(cloudera-manager-installer ...
- 几乎每个文件里面都有 #ifdef __cplusplus extern "C" { #endif 可我没找到程序里那个地方定义了__cplusplus 啊?这又是怎么回事呢?
我们的C语言有个进化版,叫C++,这个想必楼主知道,Keil MDK是支持C++编程的,也就是说,你可以用C语言或者C++写你的程序,都可以. 但是,有一个问题,就是头文件的问题,C语言写的头文件C+ ...
- IOS网络多线程-GCD
Grand Central Dispatch (GCD)是Apple开发的一个多核编程的解决方法. dispatch queue分成以下三种: 1)运行在主线程的Main queue,通过dispat ...
- 解决libpython2.6.so.1.0: cannot open shared object file
文章解决的问题:安装nginx中需要Python2.6的支持,下面介绍如何安装Python2.6,并建立lib的连接. 问题展示:error while loading shared librarie ...
- 剖析iphone之触摸事件touchstart
今天做项目发现一个问题,貌似从前没有遇到过,就记录一下,以后方便看.....(代码只显示了js这部分 样式结构都会写) 一般我们绑定click触发事件都是直接用onclick 或者方便一点click, ...