首页 > 数据库 > MySQL > 正文

MySQL性能调优之分区表的知识点有什么

2024-07-24 12:33:06
字体:
来源:转载
供稿:网友
  对于用户而言,分区表是一个独立的逻辑表,但是底层是由多个物理子表组成。分区表对于用户而言是一个完全封装底层实现的黑盒子,对用户而言是透明的,从文件系统中可以看到多个使用#分隔命名的表文件。
  mysql在创建表时使用partition by子句定义每个分区存放的数据,在执行查询的时候,优化器会根据分区定义过滤那些没有我们需要数据的分区,这样查询就无须扫描所有分区。
  分区的主要目的是将数据安好一个较粗的力度分在不同的表中,这样可以将相关的数据存放在一起。
  接下来,我将从以下6个方面来谈谈分区表,分别是分区表的应用场景、分区表的限制、分区表的原理、分区表的类型、如何使用分区表、在使用分区表的时候需要注意的问题。
 
  一、分区表的应用场景
  1、表非常大以至于无法全部都放在内存中,或者只在表的最后部分有热点数据,其他均是历史数据。
 
  2、分区表的数据更容易维护
 
  (1)批量删除大量数据可以使用清除整个分区的方式
 
  (2)对一个独立分区进行优化、检查、修复等操作
 
  3、分区表的数据可以分布在不同的物理设备上,从而高效地利用多个硬件设备
 
  4、可以使用分区表来避免某些特殊的瓶颈
 
  (1)innodb的单个索引的互斥访问
 
  (2)ext3文件系统的inode锁竞争
 
  5、可以备份和恢复独立的分区
 
  二、 分区表的原理
  分区表由多个相关的底层表实现,这个底层表也是由句柄对象标识,我们可以直接访问各个分区。存储引擎管理分区的各个底层表和管理普通表一样(所有的底层表都必须使用相同的存储引擎),分区表的索引知识在各个底层表上各自加上一个完全相同的索引。从存储引擎的角度来看,底层表和普通表没有任何不同,存储引擎也无须知道这是一个普通表还是一个分区表的一部分。分区表的操作按照以下的操作逻辑进行:
 
  1、select查询
 
  当查询一个分区表的时候,分区层先打开并锁住所有的底层表,优化器先判断是否可以过滤部分分区,然后再调用对应的存储引擎接口访问各个分区的数据
 
  2、insert操作
 
  当写入一条记录的时候,分区层先打开并锁住所有的底层表,然后确定哪个分区接受这条记录,再将记录写入对应底层表。
 
  3、 update操作
 
  当更新一条记录时,分区层先打开并锁住所有的底层表,mysql先确定需要更新的记录再哪个分区,然后取出数据并更新,再判断更新后的数据应该再哪个分区,最后对底层表进行写入操作,并对源数据所在的底层表进行删除操作。

(编辑:武林网)

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表