mysql表分区使用及详细介绍一、分区概念
分区是将一个表分成多个区块进行操作和保存 , 从而降低每次操作的数据,提高性能 。而对于应用来说则是透明的,从逻辑上看只有一张表,但在物理上这个表可能是由多个物理分区组成的,每个分区都是独立的对象,可以进行独立处理 。
二、分区作用
1.可以逻辑数据分割,分割数据能够有多个不同的物理文件路径 。
2.可以存储更多的数据,突破系统单个文件最大限制 。
3.提升性能,提高每个分区的读写速度,提高分区范围查询的速度 。
4.可以通过删除相关分区来快速删除数据
5.通过跨多个磁盘来分散数据查询 , 从而提高磁盘I/O的性能 。
6.涉及到例如SUM()、COUNT()这样聚合函数的查询,可以很容易的进行并行处理 。
7.可以备份和恢复独立的分区,这对大数据量很有好处 。
三、分区能支持的引擎
MySQL支持大部分引擎创建分区 , 入MyISAM、InnoDB等;不支持MERGE和CSV等来创建分区 。同一个分区表中的所有分区必须是同一个存储引擎 。值得注意的是 , 在MySQL8版本中 , MyISAM表引擎不支持分区 。
四、确认MySQL支持分区
从MySQL5.1开始引入分区功能,可以如下方式查看是否支持:
老版本用:SHOW VARIABLES LIKE '%partition%';
新版本用:show plugins;
五、分区类型
1. RANGE分区:基于属于一个给定连续区间的列值 , 把多行分配给分区 。
例如,可以将一个表通过年份划分成两个分区,2001 -2010年、2011-2020 。
2. LIST分区:类似于RANGE分区,LIST是列值匹配一个离散值集合中的某个值来进行选择 。
比如 根据字段 把值为1、3、5的放到一起,2、4、6的另外放到一起 等等...
3. HASH分区:基于用户定义的表达式的返回值来进行选择分区,该表达式使用将要插入到表中的这些行的列值来进行计算,这个函数必须产生非负整数值 。
通过HASH运算来进行分区,分布的比较均匀
4. KEY分区:类似于按HASH分区,由MySQL服务器提供其自身的哈希函数 。
按照KEY进行分区类似于按照HASH分区
六、分区创建注意事项
1.如果表中存在primary key 或者 unique key 时,分区的列必须是paimary key或者unique key的一个组成部分,也就是说,分区函数的列只能从pk或者uk这些key中取子集
2.如果表中不存在任何的paimary key或者unique key,则可以指定任何一个列作为分区列
3. 5.5版本前的RANGE、LIST、HASH分区要求分区键必须是int;MySQL5.5及以上,支持非整形的RANGE和LIST分区,即:range columns 和 list columns (可以用字符串来进行分区) 。
七、分区命名
1. 分区的名字基本上遵循其他MySQL 标识符应当遵循的原则,例如用于表和数据库名字的标识符 。应当注意的是,分区的名字是不区分大小写的。
2. 无论使用何种类型的分区,分区总是在创建时就自动的顺序编号,且从0开始记录 。
八、 创建分区
1. RANGE分区:
CREATE TABLE `test01` (
`dayid` int(11) DEFAULT NULL,
`mac` varchar(32) NOT NULL DEFAULT '',
`dtype` varchar(50) NOT NULL DEFAULT ''
) ENGINE=InnoDB DEFAULT CHARSET=utf8
/*!50100 PARTITION BY LIST (dayid)
(PARTITION p20171205 VALUES IN (20171205) ENGINE = InnoDB,
PARTITION p20171204 VALUES IN (20171204) ENGINE = InnoDB,
PARTITION p20171206 VALUES IN (20171206) ENGINE = InnoDB,
PARTITION p20171207 VALUES IN (20171207) ENGINE = InnoDB) */
解读:以上为 uuid小于5时放到p0分区下,uuid大于5且小于10放到p1分区下 , uuid大于10且小于15放到p2分区下,uuid大于15 一直到最大值的存在p3分区下
推荐阅读
- python爬虫新增mysql,python增量爬虫
- 大侠驿馆经营游戏,大侠网络科技有限公司
- 直播间见面技巧,第一次直播怎么和别人打招呼
- 直接看go语言实战 go语言自学
- JAVA分层窗口代码,java分层架构设计
- 电脑启动蓝屏怎么找回硬盘,电脑蓝屏怎么一键恢复,发现不了硬盘
- 虎牙直播怎么购买粉,虎牙如何买粉丝
- linux限制用户命令 linux限制用户cpu使用率
- 电脑密码用u盘怎么重置密码,电脑重置密码的u盘