FROM information_schema.PARTITIONS WHERE PARTITION_NAME IS NOT NULL
GROUP BY TABLE_NAME ORDER BY CNT DESC LIMIT 50;
三、分析执行语句
explain partitions select * from range_datetime where hiredate = '20151207124503' and hiredate='20151210111230';
四、分区管理
常规HASH和线性HASH的增加收缩分区的原理是一样的 。增加和收缩分区后原来的数据会根据现有的分区数量重新分布 。HASH分区不能删除分区,所以不能使用DROP PARTITION操作进行分区删除操作;
只能通过ALTER TABLE ... COALESCE PARTITION num来合并分区,这里的num是减去的分区数量;
可以通过ALTER TABLE ... ADD PARTITION PARTITIONS num来增加分区,这里是null是在原先基础上再增加的分区数量 。
十、MySQL表分区 ??表分区是将?个表的数据按照?定的规则?平划分为不同的逻辑块,并分别进?物理存储,这个规则就叫做分区函数,可以有不同的分区规则 。5.7可以通过show plugins语句查看当前MySQL是否?持表分区功能 。
??但当表中含有主键或唯?键时,则每个被?作分区函数的字段必须是表中唯?键和主键的全部或?部分,否则就?法创建分区表 。?如下?的表由于唯?键和主键没有相同的字段,所以?法创建表分区
上述例?中删除唯?键,确保主键中的字段包含分区函数中的所有字段 , 创建成功
或者将主键扩展为包含ref字段
表分区的主要优势在于:
??可以允许在?个表?存储更多的数据,突破磁盘限制或者?件系统限制
??对于从表?将过期或历史的数据移除在表分区很容易实现,只要将对应的分区移除即可
??对某些查询和修改语句来说,可以?动将数据范围缩?到?个或?个表分区上,优化语句执?效率 。?且可以通过显示指定表分区来执?语句,?如 SELECT * FROM t PARTITION (p0,p1) WHERE c5
表分区类型分为:
范围表分区,按照?定的范围值来确定每个分区包含的数据,分区函数使?的字段必须只能是整数类型,分区的定义范围必须是连续的,且不能有重叠部分 , 通过使?VALUES LESS THAN来定义分区范围,表分区的范围定义是从?到?定义的
?如:
??Store_id6的数据被放在p0分区?,6=store_id10之间的数据被放在p1分区? , 以此类推 , 当新插?的数据为(72, ‘Mitchell’, ‘Wilson’, ‘1998-06-25’, NULL, 13) 时 , 则新数据被插?到p2分区?,但当插?的数据的store_id为21时,由于没有分区去容纳此数据,所以会报错,我们需要修改?下表的定义
报错:
修改表的定义:
??MAXVALUE关键词的作?是表示可能的最?值,所以任何store_id=16的数据都会被写?到p3分区? 。分区函数中也可以使?表达式,?如:
??对timestamp字段类型可以使?的表达式?前仅有unix_timestamp,其他的表达式都不允许
列表表分区,按照?个?个确定的值来确定每个分区包含的数据,通过PARTITION BY LIST(expr)分区函数表达式必须返回整数,取值范围通过VALUES IN (value_list)定义
对List表分区来说,没有MAXVALUE特殊值,所有的可能取值都需要再VALUES IN中包含,如果有未定义的取值则会报错
同样,当有主键或者唯?键存在的情况下,分区函数字段需要包含在主键或唯?键中
对range和list表分区来说,分区函数可以包含多个字段 , 分区多字段函数(column partition)所涉及的字段类型可以包括:
范围多字段分区函数与普通的范围分区函数的区别在于:
a) 字段类型多样化
b) 范围多字段分区函数不?持表达式,只能?字段名
c) 范围多字段分区函数?持?个或多个字段
再?如创建如下的表分区:
对多列对?来说:
推荐阅读
- 过关小游戏经营,过关小游戏经营类游戏
- 游戏怎么用显卡截图快捷键,怎么用显卡玩游戏
- 微信公众号直播怎么做的,微信公众号直播怎么弄
- 包含python内建函数使用的词条
- 即时战略游戏情侣网名,好玩的即时战略类游戏
- 字符串的截取方式js,截取字符串的函数js
- php源码自带数据库 php+mysql源码
- word文件怎么用微信发,word文件怎么用微信发送
- ios怎么变为ghost,iso改成gho