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 
from 
INFORMATION_SCHEMA.partitions 
where  table_schema='test1' 
 and table_name = 'emp_list';

其中
table_schema为database,而table_name为分区表。expressio-n为敏感词(分开写了)

+----------------+----------------------+-----------------------+------------+

| partition_name | partition_expressio-n | partition_description
| table_rows |

+----------------+----------------------+-----------------------+------------+

| p1     
     
 | deptno   
     
     |
1     
     
     
   | 
     
  2 |

| p2     
     
 | deptno   
     
     |
2     
     
     
   | 
     
  2 |

| p3     
     
 | deptno   
     
     |
3     
     
     
   | 
     
  1 |

+----------------+----------------------+-----------------------+------------+

mysql> select count(1) from emp_list;

+----------+

| count(1) |

+----------+

|     
  5 |

+----------+

1 row in set (0.00 sec)

mysql之分区表的更多相关文章

  1. Mysql的分区表

    概论: 分区表一般用作Mysql库表的水平切割(也就是常说的mysql性能优化的几种通用手法"读写分离.分库分表"中的一种),适用于单表的数据量可能很大的场景.因为分区表可以将一个 ...

  2. mysql使用 分区表使用,常用sql

    mysql使用 分区表使用,常用sql 前言 本文的原文连接是: https://blog.csdn.net/freewebsys/article/details/84839478未经博主允许不得转载 ...

  3. mysql 案例~ 分区表

    一 简介:今天来聊聊分区表的概念和维护二分区的优点:  1.提高查询性能:只需要搜索特定分区,而非整张表,提高了查询速度.  2.节约维护时间:单个分区的数据装载,索引重建,备份,维护远远小于整张表的 ...

  4. 【mysql】分区表

    分区表是什么? 分区表可以按照事先创建的规则,对mysql的记录进行分组,每一个组具有一个独立的逻辑单元来存储该组的数据.典型的如:按照创建时间的年份分组,按照id的顺序分组(每1000万条数据分一个 ...

  5. 将mysql非分区表转换为分区表(转)

    查看表的分布状况mysql> select count(*) from  justin;+----------+| count(*) |+----------+|  5845246 |+---- ...

  6. MySQL分区表的使用

    MySQL使用分区表的好处: 1,可以把一些归类的数据放在一个分区中,可以减少服务器检查数据的数量加快查询. 2,方便维护,通过删除分区来删除老的数据. 3,分区数据可以被分布到不同的物理位置,可以做 ...

  7. 互联网公司为啥不使用mysql分区表?

    转:http://www.cnblogs.com/zhulin516114/p/7306708.html 缘起:有个朋友问我分区表在58的应用,我回答不出来,在我印象中,百度.58都没有听说有分区表相 ...

  8. 【58沈剑架构系列】互联网公司为啥不使用mysql分区表?

    缘起:有个朋友问我分区表在58的应用,我回答不出来,在我印象中,百度.58都没有听说有分区表相关的应用,业内进行一些技术交流的时候也更多的是自己分库分表,而不是使用分区表.于是去网上查了一下,并询问了 ...

  9. MYSQL分区表功能测试简析

    1.查看Mysql版本是否支持分区  SHOW VARIABLES LIKE '%partition%';   +-------------------+-------+ | Variable_nam ...

随机推荐

  1. 性能测试-CPU瓶颈分析的思路

    CPU(中央处理器),是电子计算机的主要设备之一,电脑中的核心配件.CPU作为计算机系统的运算和控制核心,是信息处理.程序运行的最终执行单元.CPU的功效主要为处理指令.执行操作.控制时间.处理数据. ...

  2. 快速掌握Java8 Stream函数式编程技巧

    函数式编程优势 "函数第一位",即函数可以出现在任何地方. 可以把函数作为参数传递给另一个函数,还可以将函数作为返回值. 让代码的逻辑更清晰更优雅. 减少了可变量(Immutabl ...

  3. mysql8在生产环境中的配置

    一,配置文件的位置 [root@yjweb ~]# ll /etc/my.cnf -rw-r--r-- 1 root root 935 Mar 11 16:52 /etc/my.cnf 说明:通常我们 ...

  4. centos8平台使用pstree查看进程树

    一,pstree用途 Linux pstree命令将所有行程以树状图显示,树状图将会以 pid (如果有指定) 或是以 systemd 这个基本行程为根 (root) 说明:centos6及更旧版本为 ...

  5. 企业级RPC框架zRPC

    近期比较火的开源项目go-zero是一个集成了各种工程实践的包含了Web和RPC协议的功能完善的微服务框架,今天我们就一起来分析一下其中的RPC部分zRPC. zRPC底层依赖gRPC,内置了服务注册 ...

  6. python执行 sql 语句

    写的很好 import pymysql conn = pymysql.connect(host = '127.0.0.1',port = 3306,user = 'root',passwd = '12 ...

  7. Jenkins配置,tomacat版本输出乱码和页面打开报404的问题

    1.打开tomact下的startup.bat,tomcat版本控制台中文输出乱码,解决方法是去tomacat安装路径下的conf目录,打开logging.properties文件,将java.uti ...

  8. 从原生web组件到框架组件源码(一)

    温馨提醒,当你觉得看我写的很乱的时候,就对了,那是因为我查阅了大量的资料提取出来的,因为有点东西不太理解,所以你会感觉有的部分重复了,也不是重复,只是后面对前面的内容进行梳理了一些,需要耐心的看到最后 ...

  9. JAVA类库之——Math类(持续更新)

    Math类 目录 Math类 1.Math 类中的常量方法 返回π(圆周率)值的方法:PI 返回E(自然对数低)值的方法:E 2.Math 类中的三角函数方法 计算正弦函数值的方法:Sin(radia ...

  10. IOCP 模型1

    // IOCP.cpp : Defines the entry point for the console application. // // #include "stdafx.h&quo ...