分区表

CREATE TABLE tr (id INT, name VARCHAR(50), purchased DATE)        PARTITION BY RANGE( YEAR(purchased) ) (            PARTITION p0 VALUES LESS THAN (1990),            PARTITION p1 VALUES LESS THAN (1995),            PARTITION p2 VALUES LESS THAN (2000),            PARTITION p3 VALUES LESS THAN (2005),            PARTITION p4 VALUES LESS THAN (2010),            PARTITION p5 VALUES LESS THAN (2015)        );

应用场景

分区表的限制

MyISAM 分区表使用的是通用分区策略,在 Server 层会打开所有分区表文件,这可能造成过多文件句柄错误

MySQL 5.7.9 开始,InnoDB 引擎引入了本地分区策略,也就是由引擎管理

从 server 层看的话,一个分区表就只是一个表,所以所有分区表是共用一个 MDL的

原理

select查询

​ 当查询一个分区表的时候,分区层先打开并锁住所有的底层表,优化器先判断是否可以过滤部分分区,然后再调用对应的存储引擎接口访问各个分区的数据

insert操作

​ 当写入一条记录的时候,分区层先打开并锁住所有的底层表,然后确定哪个分区接受这条记录,再将记录写入对应底层表

delete操作

​ 当删除一条记录时,分区层先打开并锁住所有的底层表,然后确定数据对应的分区,最后对相应底层表进行删除操作

update操作

​ 当更新一条记录时,分区层先打开并锁住所有的底层表,mysql先确定需要更新的记录再哪个分区,然后取出数据并更新,再判断更新后的数据应该再哪个分区,最后对底层表进行写入操作,并对源数据所在的底层表进行删除操作

分区表类型

分区表使用

根据分区规则大致定位需要的数据为止,通过使用where条件将需要的数据限制在少数分区中,这种策略适用于以正常的方式访问大量数据

如果数据有明显的热点,而且除了这部分数据,其他数据很少被访问到,那么可以将这部分热点数据单独放在一个分区中,让这个分区的数据能够有机会都缓存在内存中

注意问题