网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

mysql分区表笔记

MySQL分区表
   mysql分区表是一个独立的逻辑表,但是底层由多个物理字表组成。
   对分区的请求,都会通过句柄对象转化成对存储引擎接口的调用。所以分区对于
对于sql层来说是一个完全封装底层实现的黑盒子,对应用是透明的。
   Mysql实现分区表的方式--对底层表的封装--意味着索引也是按照分区的字表定义的,而没有全局索引。
适合场景:
   表中只有最后部分数据是热点数据,其他均为临时数据。
   分区表中数据更容易维护,可以对独立的分区进行优化,检查、修复等操作
   分区表数据可以分布在不同物理设备上,从而高效地利用多个硬件设备
   可以备份和恢复独立的分区,这在非常大的数据集的场景下效果非常好。
   
分区限制:
   一个分区表只能有1024个分区
   如果分区字段中有主键或者唯一索引的列,那么所有主键列和唯一索引列都必须包含进来。
   利用分区表来避免某些特殊的瓶颈,例如Innodb的单个索引的互斥访问ext3文件系统的inode锁竞争等。
   分区表无法使用外键约束。
   
分区表的原理
   从存储引擎的角度来看,底层表和一个普通的表没有任何不同,存储引擎也无需知道这是一个普通表还是一个分区表的一部分。
   
select查询
   分区表的类型
   mysql支持多种分区表。分区表达式可以是列,也可以是包含列的表达式。例如,下表就可以将每一年的销售额存放在不同的分区里。
   create table  sales(
   order_date datetime not null,
   --Other columns 
   )engine=InnoDB partition by range(Year(order_date))(
   partition  p_2010  values  less then (2010),
   partition p_2011   values  less then(2011),
   partition p_catchall values  less then maxvalue);
   
   mysql还支持键值,哈希和列表分区。
   系统通过子分区可降低索引的互斥访问的竞争。最近一年的分区的数据会被非常频繁地访问,这会导致大量的互斥锁的竞争。使用哈希子分区可以
将数据切成多个小片,大大降低互斥量的竞争问题。
   

当前文章:mysql分区表笔记
链接URL:http://bjjierui.cn/article/jiiheg.html

其他资讯