首页 数据库 mysql教程 MySQL分区表_MySQL

MySQL分区表_MySQL

Jun 01, 2016 pm 01:06 PM

1 分区表简介

    数据库分区是一种物理数据库设计技术。虽然分区技术可以实现很多效果,但其主要目的是为了在特定的SQL操作中减少数据读写的总量以缩减sql语句的响应时间,同时对于应用来说分区完全是透明的。

    分区表是一种粗粒度,简易的索引策略,适用于大数据的过滤场景.最适合的场景是,没有合适的索引时,对其中几个分区表进行全表扫描.或者只有一个分区表和索引是热点,而且这个分区和索引能够全部存储在内存中.限制单表分区数不要超过150个,并且注意某些导致无法做分区过滤的细节,分区表对于单条记录的查询没有优势,需要注意这类查询的性能。

2 分区表优缺点

    2.1 分区表优点

    可以把一些归类的数据放在一个分区中,可以减少服务器检查数据的数量加快查询。
    方便维护,通过删除分区来删除老的数据。
    分区数据可以被分布到不同的物理位置,可以做分布式有效利用多个硬盘驱动器。

    可以优化、检查、修复个别分区。

    根据查找条件,也就是where后面的条件,查找只查找相应的分区不用全部查找了。
    进行大数据搜索时可以进行并行处理。
    跨多个磁盘来分散数据查询,来获得更大的查询吞吐量。

    2.2 分区表缺点

    每张表最大分区数为1024。
    所有的主键或者唯一索引必须被包含在分区表达式中。
    不能使用任何外键约束。

3 分区类型

    MYSQL的分区主要有两种形式:水平分区和垂直分区。

    3.1 水平分区(根据列属性按行分)

    这种形式的分区是对根据表的行进行分区,通过这样的方式不同分组里面的物理列分割的数据集得以组合,从而进行个体分割(单分区)或集体分割(1个或多个分区)。
所有在表中定义的列在每个数据集中都能找到,所以表的特性依然得以保持。水平分区一定要通过某个属性列来分割。常见的比如年份,日期等。

    例如:一个包含十年发票记录的表可以被分区为十个不同的分区,每个分区包含的是其中一年的记录。

        3.1.1 水平分区几种模式:

        Range(范围) – 这种模式允许DBA将数据划分不同范围。例如DBA可以将一个表通过年份划分成三个分区,80年代(1980's)的数据,90年代(1990's)的数据以及任何在2000年(包括2000年)后的数据。
        Hash(哈希) – 这中模式允许DBA通过对表的一个或多个列的Hash Key进行计算,最后通过这个Hash码不同数值对应的数据区域进行分区,。例如DBA可以建立一个对表主键进行分区的表。  Key(键值) – 上面Hash模式的一种延伸,这里的Hash Key是MySQL系统产生的。
        List(预定义列表) – 这种模式允许系统通过DBA定义的列表的值所对应的行数据进行分割。例如:DBA建立了一个横跨三个分区的表,分别根据2004年2005年和2006年值所对应的数据。   

        Composite(复合模式) - 其实是以上模式的组合使用而已。例如:在初始化已经进行了Range范围分区的表上,我们可以对其中一个分区再进行hash哈希分区。

    3.2 垂直分区(按列分)

    这种分区方式一般来说是通过对表的垂直划分来减少目标表的宽度,使某些特定的列被划分到特定的分区,每个分区都包含了其中的列所对应所有行。

    例如:一个包含了大text和BLOB列的表,这些text和BLOB列又不经常被访问,这时候就要把这些不经常使用的text和BLOB了划分到另一个分区,在保证它们数据相关性的同时还能提高访问速度。

4 实例分析

    4.1 查看分区表

    查看是否支持分区

mysql> show variables like '%partition%';+-------------------+-------+| Variable_name     | Value |+-------------------+-------+| have_partitioning | YES   |+-------------------+-------+mysql> show plugins;+--------------------------+----------+--------------------+---------+-------------+| Name                     | Status   | Type               | Library | License     |+--------------------------+----------+--------------------+---------+-------------+| binlog                   | ACTIVE   | STORAGE ENGINE     | NULL    | PROPRIETARY || mysql_native_password    | ACTIVE   | AUTHENTICATION     | NULL    | PROPRIETARY || mysql_old_password       | ACTIVE   | AUTHENTICATION     | NULL    | PROPRIETARY || MEMORY                   | ACTIVE   | STORAGE ENGINE     | NULL    | PROPRIETARY || MyISAM                   | ACTIVE   | STORAGE ENGINE     | NULL    | PROPRIETARY || CSV                      | ACTIVE   | STORAGE ENGINE     | NULL    | PROPRIETARY || MRG_MYISAM               | ACTIVE   | STORAGE ENGINE     | NULL    | PROPRIETARY || InnoDB                   | ACTIVE   | STORAGE ENGINE     | NULL    | PROPRIETARY || INNODB_BUFFER_POOL_STATS | ACTIVE   | INFORMATION SCHEMA | NULL    | PROPRIETARY || PERFORMANCE_SCHEMA       | ACTIVE   | STORAGE ENGINE     | NULL    | PROPRIETARY || FEDERATED                | DISABLED | STORAGE ENGINE     | NULL    | PROPRIETARY || BLACKHOLE                | ACTIVE   | STORAGE ENGINE     | NULL    | PROPRIETARY || ARCHIVE                  | ACTIVE   | STORAGE ENGINE     | NULL    | PROPRIETARY || partition                | ACTIVE   | STORAGE ENGINE     | NULL    | PROPRIETARY |+--------------------------+----------+--------------------+---------+-------------+
登录后复制
    4.2 Range分区

    创建range分区表

CREATE TABLE IF NOT EXISTS `user` (      `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '用户ID',      `name` varchar(50) NOT NULL DEFAULT '' COMMENT '名称',      `sex` int(1) NOT NULL DEFAULT '0' COMMENT '0为男,1为女',      PRIMARY KEY (`id`)  ) ENGINE=Innodb  DEFAULT CHARSET=utf8 AUTO_INCREMENT=1  PARTITION BY RANGE (id) (      PARTITION p0 VALUES LESS THAN (3),      PARTITION p1 VALUES LESS THAN (6),      PARTITION p2 VALUES LESS THAN (9),      PARTITION p3 VALUES LESS THAN (12),      PARTITION p4 VALUES LESS THAN MAXVALUE   );  
登录后复制

    插入一些数据

INSERT INTO `user` (`name` ,`sex`)VALUES ('name1', '0'),('name2',1),('name3',1),('name4',1),('name5',0),('name6',1),('name7',1),('name8',1),('name9',1),('name10',1),('name11',1),('name12',1),('name13',1),('name14',1),('name15',1),('name16',1);
登录后复制

    查看分区表信息

SHOW CREATE TABLE user;
SHOW TABLE STATUS LIKE 'user';

    查看各分区信息

mysql> SELECT TABLE_NAME,PARTITION_NAME,PARTITION_EXPRESSION,PARTITION_DESCRIPTION,TABLE_ROWS,AVG_ROW_LENGTH/1024 as 'AVG_ROW_LENGTH (KB)',DATA_LENGTH/(1024*1024) as 'DATA_LENGTH (MB)',MAX_DATA_LENGTH/(1024*1024*1024*1024) as 'MAX_DATA_LENGTH (TB)',INDEX_LENGTH/(1024*1024) as 'INDEX_LENGTH (MB)',UPDATE_TIME,CHECK_TIME FROM INFORMATION_SCHEMA.PARTITIONS WHERE TABLE_NAME='user' AND TABLE_SCHEMA='test1';
登录后复制



5 分区管理

6 分区表和未分区表性能对比


转载请注明出处:http://blog.csdn.net/jesseyoung/article/details/37813331

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
2 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何使用Alter Table语句在MySQL中更改表? 如何使用Alter Table语句在MySQL中更改表? Mar 19, 2025 pm 03:51 PM

本文讨论了使用MySQL的Alter Table语句修改表,包括添加/删除列,重命名表/列以及更改列数据类型。

如何为MySQL连接配置SSL/TLS加密? 如何为MySQL连接配置SSL/TLS加密? Mar 18, 2025 pm 12:01 PM

文章讨论了为MySQL配置SSL/TLS加密,包括证书生成和验证。主要问题是使用自签名证书的安全含义。[角色计数:159]

您如何处理MySQL中的大型数据集? 您如何处理MySQL中的大型数据集? Mar 21, 2025 pm 12:15 PM

文章讨论了处理MySQL中大型数据集的策略,包括分区,碎片,索引和查询优化。

哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么? 哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么? Mar 21, 2025 pm 06:28 PM

文章讨论了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比较了它们对初学者和高级用户的功能和适合性。[159个字符]

如何使用Drop Table语句将表放入MySQL中? 如何使用Drop Table语句将表放入MySQL中? Mar 19, 2025 pm 03:52 PM

本文讨论了使用Drop Table语句在MySQL中放下表,并强调了预防措施和风险。它强调,没有备份,该动作是不可逆转的,详细介绍了恢复方法和潜在的生产环境危害。

您如何用外国钥匙代表关系? 您如何用外国钥匙代表关系? Mar 19, 2025 pm 03:48 PM

文章讨论了使用外国密钥来代表数据库中的关系,重点是最佳实践,数据完整性和避免的常见陷阱。

如何在JSON列上创建索引? 如何在JSON列上创建索引? Mar 21, 2025 pm 12:13 PM

本文讨论了在PostgreSQL,MySQL和MongoDB等各个数据库中的JSON列上创建索引,以增强查询性能。它解释了索引特定的JSON路径的语法和好处,并列出了支持的数据库系统。

如何保护MySQL免受常见漏洞(SQL注入,蛮力攻击)? 如何保护MySQL免受常见漏洞(SQL注入,蛮力攻击)? Mar 18, 2025 pm 12:00 PM

文章讨论了使用准备好的语句,输入验证和强密码策略确保针对SQL注入和蛮力攻击的MySQL。(159个字符)

See all articles