欢迎来到天天文库
浏览记录
ID:39553248
大小:53.50 KB
页数:9页
时间:2019-07-06
《创建mysql表分区的方法》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、创建mysql表分区的方法我来给大家介绍一下mysql表分区创建与使用吧,希望对各位同学会有所帮助。表分区的测试使用,主要内容来自于其他博客文章以及mysql5.1的参考手册。表分区是最近才知道的哦,以前自己做都是分表来实现上亿级别的数据了,下面我来给大家介绍一下mysql表分区创建与使用吧,希望对各位同学会有所帮助。表分区的测试使用,主要内容来自于其他博客文章以及mysql5.1的参考手册mysql测试版本:mysql5.5.28mysql物理存储文件(有mysql配置的datadir决定存储路径)格式简介数据库engine为MYISAMfrm表结构文件,myd表数据文件,myi
2、表索引文件。INNODBengine对应的表物理存储文件innodb的数据库的物理文件结构为:.frm文件.ibd文件和.ibdata文件:这两种文件都是存放innodb数据的文件,之所以用两种文件来存放innodb的数据,是因为innodb的数据存储方式能够通过配置来决定是使用共享表空间存放存储数据,还是用独享表空间存放存储数据。独享表空间存储方式使用.ibd文件,并且每个表一个ibd文件共享表空间存储方式使用.ibdata文件,所有表共同使用一个ibdata文件创建分区分区的一些优点包括:·与单个磁盘或文件系统分区相比,可以存储更多的数据。·对于那些已经失去保存意义的数据,通常
3、可以通过删除与那些数据有关的分区,很容易地删除那些数据。相反地,在某些情况下,添加新数据的过程又可以通过为那些新数据专门增加一个新的分区,来很方便地实现。通常和分区有关的其他优点包括下面列出的这些。MySQL分区中的这些功能目前还没有实现,但是在我们的优先级列表中,具有高的优先级;我们希望在5.1的生产版本中,能包括这些功能。·一些查询可以得到极大的优化,这主要是借助于满足一个给定WHERE语句的数据可以只保存在一个或多个分区内,这样在查找时就不用查找其他剩余的分区。因为分区可以在创建了分区表后进行修改,所以在第一次配置分区方案时还不曾这么做时,可以重新组织数据,来提高那些常用查询
4、的效率。· 涉及到例如SUM()和COUNT()这样聚合函数的查询,可以很容易地进行并行处理。这种查询的一个简单例子如“SELECTsalesperson_id,COUNT(orders)asorder_totalFROMsalesGROUPBYsalesperson_id;”。通过“并行”,这意味着该查询可以在每个分区上同时进行,最终结果只需通过总计所有分区得到的结果。· 通过跨多个磁盘来分散数据查询,来获得更大的查询吞吐量。简而言之就是数据管理优化,查询更快,数据查询并行检测mysql是否支持分区复制代码代码如下:mysql>showvariableslike"%partit
5、ion%";+-------------------+-------+
6、Variable_name
7、Value
8、+-------------------+-------+
9、have_partitioning
10、YES
11、+-------------------+-------+1rowinsetRANGE分区:基于属于一个给定连续区间的列值,把多行分配给分区。复制代码代码如下:DROPTABLEIFEXISTS`p_range`;CREATETABLE`p_range`(`id`int(10)NOTNULLAUTO_INCREMENT,`name`char(20)NOTNULL,
12、PRIMARYKEY(`id`))ENGINE=MyISAMAUTO_INCREMENT=9DEFAULTCHARSET=utf8/*!50100PARTITIONBYRANGE(id)(PARTITIONp0VALUESLESSTHAN(8)ENGINE=MyISAM)*/;range分区就是partitionbyrange(id)表示按id1-7的数据存储在p0分区;如果id大于7了则数据不能写入了,因为没有对应的数据分区来存储;所以这时在创建分区时需要使用maxvalues关键字了复制代码代码如下:PARTITIONBYRANGE(id)(PARTITIONp0VALUESL
13、ESSTHAN(8),PARTITIONp1VALUESLESSTHANMAXVALUE)这样就表示,所有id大于7的数据记录存在在p1分区里。RANGE分区在如下场合特别有用:· 当需要删除“旧的”数据时。如果你使用上面最近的那个例子给出的分区方案,你只需简单地使用“ALTERTABLEemployeesDROPPARTITIONp0;”来删除所有在1991年前就已经停止工作的雇员相对应的所有行。对于有大量行的表,这比运行一个如“DELETEFROMemployee
此文档下载收益归作者所有