mysql垂直分区和水平分区

转载 2011年01月19日 15:53:00
数据库扩展大概分为以下几个步骤:
1、读写分离:当数据库访问量还不是很大的时候,我们可以适当增加服务器,数据库主从复制的方式将读写分离;

2、垂直分区:当写入操作一旦增加的时候,那么主从数据库将花更多的时间的放在数据同步上,这个时候服务器也是不堪重负的;那么就有了数据的垂直分区,数据的垂直分区思路是将写入操作比较频繁的数据表,如用户表_user,或者订单表_orders,那么我们就可以把这个两个表分离出来,放在不同的服务器,如果这两个表和其他表存在联表查询,那么就只能把原来的sql语句给拆分了,先查询一个表,在查询另一个,虽然说这个会消耗更过性能,但比起那种大量数据同步,负担还是减轻了不少;

3、水平分区:但是往往事情不尽人意,可能采取垂直分区能撑一段时间,由于网站太火了,访问量又每日100w,一下子蹦到了1000w,这个时候可以采取数据的进行分离,我们可以根据user的Id不同进行分配,如采取%2的形式,或者%10的形式,当然这种形式对以后的扩展有了很大的限制,当我由10个分区增加到20个的时候,所有的数据都得重新分区,那么将是一个的很庞大的计算量;以下提供几种常见的算法:
  哈希算法:就是采用user_id%的方式;
  范围:可以根据user_id字符值范围分区,如1-1000为一区,1001-2000则是另一个区等;
  映射关系:就是将user_id存在的所对应的分区放在数据库中保存,当用户操作时先去查询所在分区,再进行操作;

对于以上几种扩展方式,读写分离主要是操作上的扩展,垂直分区主要是对写入较频繁数据表的分离,水平分区主要是数据分离;
转载自:

mysql水平分表和垂直分表和数据库分区

分表是分散数据库压力的好方法。 分表,最直白的意思,就是将一个表结构分为多个表,然后,可以再同一个库里,也可以放到不同的库。 当然,首先要知道什么情况下,才需要分表。个人觉得单表记录条数达...
  • Java_Mr_Zheng
  • Java_Mr_Zheng
  • 2015年11月17日 14:18
  • 4497

深入解析MySQL分区(Partition)功能

自5.1开始对分区(Partition)有支持,6.0应比较稳定 = 水平分区(根据列属性按行分)= 举个简单例子:一个包含十年发票记录的表可以被分区为十个不同的分区,每个分区包含的是其中一年的记录...
  • tjcyjd
  • tjcyjd
  • 2013年09月06日 14:49
  • 89620

Mysql垂直分区和水平分区

Mysql垂直分区和水平分区数据库扩展大概分为以下几个步骤: 读写分离: 当数据库访问量还不是很大的时候,我们可以适当增加服务器,数据库主从复制的方式将读写分离; 垂直分区: 当写入操作一旦增加的...
  • u012546203
  • u012546203
  • 2017年03月22日 08:45
  • 422

mysql水平分表和垂直分表和数据库分区

分表是分散数据库压力的好方法。 分表,最直白的意思,就是将一个表结构分为多个表,然后,可以再同一个库里,也可以放到不同的库。 当然,首先要知道什么情况下,才需要分表。个人觉得单表记录条数达...
  • Java_Mr_Zheng
  • Java_Mr_Zheng
  • 2015年11月17日 14:18
  • 4497

Mycat 水平分表,垂直分表实践(2)

1,迁移数据举例说明,比如一个博客数据库数据表如下: 这里水平拆分,垂直拆分,只是做个简单的实验,真正的线上业务要根据情况,数据进行拆分。 mycat提供了数据库垂直拆分和水平拆分的方案,对于数据迁...
  • freewebsys
  • freewebsys
  • 2015年03月26日 13:50
  • 6648

数据库垂直拆分 水平拆分

当我们使用读写分离、缓存后,数据库的压力还是很大的时候,这就需要使用到数据库切分了。                  数据库切人简单来说,就是指通过某种特定的条件,按照某个维度,将我们存放在同一个数...
  • Jerome_s
  • Jerome_s
  • 2016年09月10日 08:48
  • 3400

mysql水平分表和垂直分表和数据库分区

mysql水平分表和垂直分表和数据库分区。 坚信数据库的物理设计在对高级数据库的性能影响上远比其他因素重要。给大家说一下经过专家对Oracle的研究,他们解释了为什么拙劣的物理设计是数据库停机(无论...
  • dragon8299
  • dragon8299
  • 2011年10月11日 21:07
  • 1287

Mysql垂直分区和水平分区

Mysql垂直分区和水平分区数据库扩展大概分为以下几个步骤: 读写分离: 当数据库访问量还不是很大的时候,我们可以适当增加服务器,数据库主从复制的方式将读写分离; 垂直分区: 当写入操作一旦增加的...
  • u012546203
  • u012546203
  • 2017年03月22日 08:45
  • 422

(转)mysql水平分表和垂直分表和数据库分区

坚信数据库的物理设计在对高级数据库的性能影响上远比其他因素重要。给大家说一下经过专家对Oracle的研究,他们解释了为什么拙劣的物理设计是数据库停机(无论是有计划的还是没计划的)背后的主要原因。但在这...
  • cs408
  • cs408
  • 2015年10月09日 20:10
  • 340

mysql水平分表和垂直分表和数据库分区

什么是数据库分区? 数据库分区是一种物理数据库设计技术,DBA和数据库建模人员对其相当熟悉。虽然分区技术可以实现很多效果,但其主要目的是为了在特定的SQL操作中减少数据读写的总量以缩减响应时间。 ...
  • aggrelxf
  • aggrelxf
  • 2013年01月24日 11:31
  • 518
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:mysql垂直分区和水平分区
举报原因:
原因补充:

(最多只允许输入30个字)