mysql之分区表
1.分区表概述:
| 1.分区表的主要意义在于,对于表结构进行划分,不同的数据进入不同的分区中,以便于在查询过程中,只查找指定分区的数据,减少数据库扫描的数据量。
2.虽然从逻辑上看分区表是一张表,但是底层却是有不同的物理分区构成,对应的底层就是不同的数据文件。 限制:唯一性索引,必须在分区列上.因为表在底层是分成的.每一段索引在每一段列上,不能跨分区进行唯一判断. |
2.分区处理NULL值的方式:
| range分区表: null被保存在最小分区
list分区: null被保存在0分区 hash和key: 被当做0 为了避免这种情况的产生,建议分区键设置成NOT NULL。 |
3.range分区
| range分区就是范围分区,根据被分区列的数据的范围,将数据路由到不同的分区中.
range: 优点:可以进行范围查询,并且筛选分区 缺点:特定分区可能数据量很大,或者具有比较多的热数据,不能平均分散数据. 关于范围分区,如果创建范围分区是为了解决单个文件的写压力问题,尽量不要使用递增的id作为分区列。 建range分区表语句: create table emp_range (empno varchar(20) not null, empname varchar(20), deptno int, birthdate date, salary int ) partition by range(salary) ( partition p1 values less than (1000), partition p2 values less than (2000), partition p3 values less than maxvalue ); 查看表文件结构: [root@master test1]# ls |grep emp emp_range.frm emp_range#P#p1.ibd emp_range#P#p2.ibd emp_range#P#p3.ibd |
4.list 列表分区:
| list就是列表分区,将固定的值,插入到固定的分区之中
建list分区表语句: create table emp_list (empno varchar(20) not null , empname varchar(20), deptno int, birthdate date not null, salary int ) partition by list(deptno) ( partition p1 values in (1), partition p2 values in (2), partition p3 values in (3) ); 表文件结构: [root@master test1]# ls |grep list emp_list.frm emp_list#P#p1.ibd emp_list#P#p2.ibd emp_list#P#p3.ibd |
5.hash分区:
| 先对列进行hash计算,然后使用取余算法对数据进行路由.
Hash分区主要用来分散热点读,确保数据在预先确定个数的分区中尽可能平均分布。 hash优点:可以打散热数据 缺点:不能进行范围查询 建hash分区语句: create table emp_hash (empno varchar(20) not null , empname varchar(20), deptno int, birthdate date not null, salary int ) partition by hash(year(birthdate)) partitions 4; 表文件结构: [root@master test1]# ls |grep hash emp_hash.frm emp_hash#P#p0.ibd emp_hash#P#p1.ibd emp_hash#P#p2.ibd emp_hash#P#p3.ibd |
6.key分区:
| hash分区只能支持数值的分区,key分区可以支持字符串分区
建key分区语句: create table emp_key (empno varchar(20) not null , empname varchar(20), deptno int, birthdate date not null, salary int ) partition by key(birthdate) partitions 4; 表文件结构: [root@master test1]# ls |grep key emp_key.frm emp_key#P#p0.ibd emp_key#P#p1.ibd emp_key#P#p2.ibd emp_key#P#p3.ibd |
7.查看分区表:
| 查看分区表的建表语句: show create table emp_list; 查看分区使用情况:从information_schema.partitions表中查询 mysql> select partition_name,partition_expressio-n,partition_description, table_rows 其中 +----------------+----------------------+-----------------------+------------+ | partition_name | partition_expressio-n | partition_description +----------------+----------------------+-----------------------+------------+ | p1 | p2 | p3 +----------------+----------------------+-----------------------+------------+ mysql> select count(1) from emp_list; +----------+ | count(1) | +----------+ | +----------+ 1 row in set (0.00 sec) |
mysql之分区表的更多相关文章
- Mysql的分区表
概论: 分区表一般用作Mysql库表的水平切割(也就是常说的mysql性能优化的几种通用手法"读写分离.分库分表"中的一种),适用于单表的数据量可能很大的场景.因为分区表可以将一个 ...
- mysql使用 分区表使用,常用sql
mysql使用 分区表使用,常用sql 前言 本文的原文连接是: https://blog.csdn.net/freewebsys/article/details/84839478未经博主允许不得转载 ...
- mysql 案例~ 分区表
一 简介:今天来聊聊分区表的概念和维护二分区的优点: 1.提高查询性能:只需要搜索特定分区,而非整张表,提高了查询速度. 2.节约维护时间:单个分区的数据装载,索引重建,备份,维护远远小于整张表的 ...
- 【mysql】分区表
分区表是什么? 分区表可以按照事先创建的规则,对mysql的记录进行分组,每一个组具有一个独立的逻辑单元来存储该组的数据.典型的如:按照创建时间的年份分组,按照id的顺序分组(每1000万条数据分一个 ...
- 将mysql非分区表转换为分区表(转)
查看表的分布状况mysql> select count(*) from justin;+----------+| count(*) |+----------+| 5845246 |+---- ...
- MySQL分区表的使用
MySQL使用分区表的好处: 1,可以把一些归类的数据放在一个分区中,可以减少服务器检查数据的数量加快查询. 2,方便维护,通过删除分区来删除老的数据. 3,分区数据可以被分布到不同的物理位置,可以做 ...
- 互联网公司为啥不使用mysql分区表?
转:http://www.cnblogs.com/zhulin516114/p/7306708.html 缘起:有个朋友问我分区表在58的应用,我回答不出来,在我印象中,百度.58都没有听说有分区表相 ...
- 【58沈剑架构系列】互联网公司为啥不使用mysql分区表?
缘起:有个朋友问我分区表在58的应用,我回答不出来,在我印象中,百度.58都没有听说有分区表相关的应用,业内进行一些技术交流的时候也更多的是自己分库分表,而不是使用分区表.于是去网上查了一下,并询问了 ...
- MYSQL分区表功能测试简析
1.查看Mysql版本是否支持分区 SHOW VARIABLES LIKE '%partition%'; +-------------------+-------+ | Variable_nam ...
随机推荐
- MeteoInfoLab脚本示例:Trajectory
示例读取HYSPLIT模式输出的气团轨迹数据文件,生成轨迹图层,并显示轨迹各节点的气压图.脚本程序: f = addfile_hytraj('D:/MyProgram/Distribution/jav ...
- 【UR #9】App 管理器
UOJ小清新题表 题目内容 UOJ链接 一句话题意:给出一个强联通的混合图,有一些有向边和无向边.删除一些边使其维持强联通的状态,求删边方案. 数据范围 \(1\leq n\leq 5000,0\le ...
- mysql间隙锁 转
前面一文 mysql锁 介绍了mysql innodb存储引擎的各种锁,本文介绍一下innodb存储引擎的间隙锁,就以下问题展开讨论 1.什么是间隙锁?间隙锁是怎样产生的? 2.间隙锁有什么作用? 3 ...
- Windows环境下vscode Live Server插件如何开启https
0x01 vscode http插件 Live Server如何开启https 在本机端的开发环境下,如果要测试一些需要HTTPS的功能可以使用mkcert给自己颁发凭证 0x02 安装步骤如下: 1 ...
- Hugo+Github 搭建个人博客(Windows环境下)
目录 Hugo+Github 搭建个人博客(Windows环境下) 1.前言 2.Differences 2.1 https vs SSH 2.2 新建的github的仓库名必须为 用户名+githu ...
- 通过命令行上传ipa到appstore
搞持续集成自动化打包上传到appstore遇到这个问题,记录一下. 其实主要就一条到命令: xcrun altool --upload-app -f xxxx.ipa -u "yanqizh ...
- Spring Aop 详解二
这是Spring Aop的第二篇,案例代码很详解,可以查看https://gitee.com/haimama/java-study/tree/master/spring-aop-demo. 阅读前,建 ...
- Spring Boot入门之Hello World
Spring Boot介绍 Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不 ...
- 基于Spring读写分离
为什么是基于Spring的呢,因为实现方案基于Spring的事务以及AbstractRoutingDataSource(spring中的一个基础类,可以在其中放多个数据源,然后根据一些规则来确定当前需 ...
- JUC---05线程间通信(一)
一.普通的线程间通信 1.synchronized实现 package com.jenne.mydemo; class ShareDataOne { private int number = 0; p ...