分区表:

分区表是一个独立的逻辑表,底层通过多个物理表实现。

mysql实现分区表的方式是对底层表的封装。这意味着没有全局索引,索引是建立在底层的每个表上的(跟ORACLE不一样)。

用到分区表的几种情况:

  • 数据量非常大,无法全部放到内存中。
  • 只有部分数据是热点数据,其他数据是历史数据。

限制:

  • 一个表只能有1024个分区,作者在100个以下是稳定的,太多会有性能问题。
  • 分区表无法使用外键约束。
  • PARTITION BY RANGE分区表达式必须是整数或者返回整数的表达式。
  • PARTITIONED BY RANGE COLUMNS分区可以接受整形,日期型,字符型作为分区参数。
  • 所有的分区都必须使用相同的存储引擎。

会出现的问题:

  • 如果使用PARTITION BY RANGE,所有在分区表达式上的null值(本身就是null或者使用一个非法值的时候)会被放在第一个分区。在做查询的时候,不仅会查询where所在的分区,还会查询第一个null所在的分区。如果第一个分区很大,那么将会有性能隐患。解决方法,把第一个分区的数据量减少。或者做一个空分区为第一个分区。

附上PARTITION BY RANGE例子:

  1. CREATE TABLE employees (
  2. id INT NOT NULL,
  3. fname VARCHAR(30),
  4. lname VARCHAR(30),
  5. hired DATE NOT NULL DEFAULT '1970-01-01',
  6. separated DATE NOT NULL DEFAULT '9999-12-31',
  7. RANGE Partitioning
  8. 3001
  9. job_code INT NOT NULL,
  10. store_id INT NOT NULL
  11. )
  12. PARTITION BY RANGE (store_id) (
  13. PARTITION p0 VALUES LESS THAN (6),
  14. PARTITION p1 VALUES LESS THAN (11),
  15. PARTITION p2 VALUES LESS THAN (16),
  16. PARTITION p3 VALUES LESS THAN (21)
  17. )
  • 分区列和索引列不匹配。例如在a列上建立了分区,在b列上建立了索引,在使用b=?进行检索的时候,如果没有a的条件来限制要扫描的分区,那么将要在每个分区上查找b索引。如果分区比较多,也是性能隐患。

EXPLAIN PARTITIONS 查看使用了哪些分区

  1. CREATE TABLE trb1 (id INT, name VARCHAR(50), purchased DATE)
  2. PARTITION BY RANGE(id)
  3. (
  4. PARTITION p0 VALUES LESS THAN (3),
  5. PARTITION p1 VALUES LESS THAN (7),
  6. PARTITION p2 VALUES LESS THAN (9),
  7. PARTITION p3 VALUES LESS THAN (11)
  8. );
  9. (1, 'desk organiser', '2003-10-15'),
  10. (2, 'CD player', '1993-11-05'),
  11. Obtaining Information About Partitions
  12. 3044
  13. (3, 'TV set', '1996-03-10'),
  14. (4, 'bookcase', '1982-01-10'),
  15. (5, 'exercise bike', '2004-05-09'),
  16. (6, 'sofa', '1987-06-05'),
  17. (7, 'popcorn maker', '2001-11-22'),
  18. (8, 'aquarium', '1992-08-04'),
  19. (9, 'study desk', '1984-09-16'),
  20. (10, 'lava lamp', '1998-12-25');
  21. mysql> EXPLAIN PARTITIONS SELECT * FROM trb1\G
  22. *************************** 1. row ***************************
  23. id: 1
  24. select_type: SIMPLE
  25. table: trb1
  26. partitions: p0,p1,p2,p3
  27. type: ALL
  28. possible_keys: NULL
  29. key_len: NULL
  30. ref: NULL
  31. rows: 10
  32. Extra: Using filesort
  33. mysql> EXPLAIN PARTITIONS SELECT * FROM trb1 WHERE id < 5\G
  34. *************************** 1. row ***************************
  35. id: 1
  36. select_type: SIMPLE
  37. table: trb1
  38. partitions: p0,p1
  39. type: ALL
  40. possible_keys: NULL
  41. key_len: NULL
  42. ref: NULL
  43. rows: 10
  44. Extra: Using where

高性能mysql 第7章 mysql高级特性之分区表的更多相关文章

  1. 高性能mysql 第1章 mysql架构与历史

    mysql逻辑架构图: 第一层 客户端 第二层(服务层):针对所有类型的存储引擎可以公共提取的部分.将存储引擎抽离之后的其他部分都在这里.如:查询解析,分析优化,内置函数,存储过程,触发器,视图. 第 ...

  2. MySQL高级特性之分区表

    对于用户而言,分区表是一个独立的逻辑表,但是在底层由多个物理子表组成.实现分区的代码实际上是对一组底层表的句柄对象的封装,对分区表的请求都会通过句柄对象转化成对存储引擎的接口调用 意义 MySQL在创 ...

  3. 《高性能MySQL》——第一章MySQL的架构与历史

    1.可以使用SHOW TABLE STATUS查询表的相关信息. 2.默认存储引擎是InnoDB,如果没有什么很特殊的要求,InnoDB引擎是我们最好的选择. 3.mysql的infobright引擎 ...

  4. 高性能mysql笔记 第一章 mysql架构

    1.1  mysql逻辑结构 第一层: 负责连接处理,授权认证,安全等事情 第二层:负责mysql的大部分核心功能 ,查询解析,分析,优化,缓存和所有的内置函数,所有跨存储引擎的功能都在这一层实现,, ...

  5. java 第七章 面向对象高级特性

    一.类的继承 (一)继承的含义 1.在Java中定义一个类时,让该类通过关键字extends继承一个已有的类,这就是类的继承(泛化). 2.被继承的类称为父类(超类,基类),新的类称为子类(派生类). ...

  6. mysql笔记04 MySQL高级特性

    MySQL高级特性 1. 分区表:分区表是一种粗粒度的.简易的索引策略,适用于大数据量的过滤场景.最适合的场景是,在没有合适的索引时,对几个分区进行全表扫描,或者是只有一个分区和索引是热点,而且这个分 ...

  7. 【MySQL高级特性】高性能MySQL第七章

    2017-07-25 14:15:43 前言:MYSQL从5.0和5.1版本开始引入了很多高级特性,例如分区.触发器等,这对有其他关系型数据库使用 背景的用户来说可能并不陌生.这些新特性吸引了很多用户 ...

  8. 干货:鲜为人用的MySQL高级特性与玩法!

    上一篇文章<万字总结:学习MySQL优化原理,这一篇就够了!>文末给大家留有两个开放的问题: 有非常多的程序员在分享时都会抛出这样一个观点:尽可能不要使用存储过程,存储过程非常不容易维护, ...

  9. MySQL高级特性

    MySQL管理 用户管理 CREATE USER username IDENTIFIED BY 'password'; 新建用户 CREATE USER@'%' IDENTIFIED BY 'pass ...

随机推荐

  1. C#编程 socket编程之unity聊天室

    上面我们创建了tcp的客户端和服务端,但是只能进行消息的一次收发.这次我们做一个unity的简易聊天室,使用了线程,可以使用多个客户端连接服务器,并且一个客户端给服务器发消息后,服务器会将消息群发给所 ...

  2. Nginx安装出现‘struct crypt_data’没有名为‘current_sal

    centos 安装nginx 时出现src/os/unix/ngx_user.c:26:7: 错误:‘struct crypt_data’没有名为‘current_sal 解决办法: 将系统换成版本低 ...

  3. Zuul网关跨域问题

    1.跨域就指着协议,域名,端口不一致,出于安全考虑,跨域的资源之间是无法交互的.简单说就是协议不通,域名不通,端口不同都会产生跨域问题 Access-Control-Allow-Origin是HTML ...

  4. celery 调用scrapy

    我的环境: celery 3.1.25 python 3.6.9 window10 celery tasks 代码如下,其中 QuotesSpider 是我的scrapy项目爬虫类名称 from ce ...

  5. CentOS7安装rabbitMQ,并实现浏览器访问

    第一.安装wget yum install wget 第二.下载erlang和rabbitmq-server的rpm (1)在/usr/local下创建目录rabbitMQ,并进入该目录 (2)下载 ...

  6. 设计模式:模板方法(Template method)

    首先我们先来看两个例子:冲咖啡和泡茶.冲咖啡和泡茶的基本流程如下: 所以用代码来创建如下: 咖啡:Caffee.java public class Coffee { void prepareRecip ...

  7. 记java的那些编辑器的故事之凌嘉文+李晓彤-结对编程

    [写在前面]这次是复用个人项目进行结对编程,其实主要复用的就是凌老板的出题部分和我的文件读写部分,其余部分都是新学的.在这次编程中也涨了很多知识,其中最最最让人哭笑不得的就是:两个人用了不一样的编辑器 ...

  8. 正确理解Widget::Widget(QWidget *parent) :QWidget(parent)这句话

    原文:https://zhuanlan.zhihu.com/p/31310536 /********原文********/ 最近很多学习Qt的小伙伴在我的微信公众号私信我,该如何理解下面段代码的第二行 ...

  9. codeforces 620C

    题目链接:https://codeforces.com/problemset/problem/620/C 题目分析 题意:给你一串珍珠,每个珍珠都有一个对应值,需要分割这n个珍珠(必须连续),使得每一 ...

  10. 小白基础Python重要的字符串详解String的内置方法

    String的内置方法: st='hello world  {name} is {age}'  {}  特殊内容需要识别format print(st.count('1')) 统计元素个数 print ...