关于数据库的水平分割和垂直分割的几点介绍

数据库
本文我们详细介绍了数据库的水平分割和垂直分割的使用场合,并给出了实际的例子加以说明,希望能够对您有所帮助。

数据库操作中,我们常常会听说这两个词语:水平分割垂直分割。那么到底什么是数据库的水平分割,什么是数据库的垂直分割呢?本文我们就来介绍一下这部分内容。

1、水平分割:

按记录进分分割,不同的记录可以分开保存,每个子表的列数相同。

水平分割通常在下面的情况下使用:

A 表很大,分割后可以降低在查询时需要读的数据和索引的页数,同时也降低了索引的层数,提高查询速度。

B 表中的数据本来就有独立性,例如表中分别记录各个地区的数据或不同时期的数据,特别是有些数据常用,而另外一些数据不常用。

C需要把数据存放到多个介质上。

例如法规表law就可以分成两个表active-law和 inactive-law。activea-authors表中的内容是正生效的法规,是经常使用的,而inactive-law表则使已经作废的法规,不常被查询。水平分割会给应用增加复杂度,它通常在查询时需要多个表名,查询所有数据需要union操作。在许多数据库应用中,这种复杂性会超过它带来的优点,因为只要索引关键字不大,则在索引用于查询时,表中增加两到三倍数据量,查询时也就增加读一个索引层的磁盘次数。

2、垂直分割:

按列进行分割,即把一条记录分开多个地方保存,每个子表的行数相同。

把主码和一些列放到一个表,然后把主码和另外的列放到另一个表中。如果一个表中某些列常用,而另外一些列不常用,则可以采用垂直分割,另外垂直分割可以使得数据行变小,一个数据页就能存放更多的数据,在查询时就会减少I/O 次数。其缺点是需要管理冗余列,查询所有数据需要join操作。 

例如有表T1

id  name  qty

--------------

1  p1    10

2  p2    20

3  p3    30

4  p4    40

......

......

垂直分割就是按列进行分割,即把一条记录分开多个地方保存,每个子表的行数相同。

例如表T1,可以把id和name放到数据文件p1,把qty放到数据文件p2。

水平分割就是按记录进分分割,不同的记录可以分开保存,每个子表的列数相同。

像表T1,可以把id为单数的放到数据文件P1,双数的放到数据文件P2。

表散列与水平分割相似,但没有水平分割那样的明显分割界限,它由哈希函数和键值决定一条记录的保存文件,这样是为了IO更加均衡。

关于数据库的垂直分割与水平分割的知识就介绍到这里了,希望本次的介绍能够对您有所收获!

【编辑推荐】

  1. 数据库集群中间件CJDBC详细介绍
  2. SQL Server 2005无法连接到本地服务器的解决
  3. Linux下重新配置MySQL数据库引擎innodb的过程
  4. SQL Server通过整理索引碎片和重建索引提高速度
  5. Linux+Oracle 10g RAC双网卡绑定和解除绑定的实现
责任编辑:赵鹏 来源: CSDN博客
相关推荐

2010-08-06 11:11:24

RIP路由协议

2011-04-13 13:30:21

eigrp帧中继

2020-11-18 09:39:02

MySQL数据库SQL

2020-07-30 17:59:34

分库分表SQL数据库

2011-08-10 15:46:29

数据库

2011-08-10 16:30:36

数据库表分区表分割

2011-08-23 15:16:54

OracleMySQL

2019-03-06 14:42:01

数据库分库分表

2011-08-05 11:01:15

MySQL数据库设计

2011-03-17 15:40:54

2011-08-16 18:29:45

SQL Server 数据货场

2011-08-01 09:50:31

SQL Server数主键索引

2023-07-27 15:38:52

数据集

2011-04-01 10:40:07

SQL Server数备份恢复

2009-01-18 17:52:15

数据仓库SQL Server数据库

2011-07-26 16:53:29

MongoDB数据库自动分片技术

2011-08-05 13:17:34

Oracle数据库闪回个性

2022-12-30 08:37:25

Kubernetes垂直水平

2011-08-11 16:08:55

Oracle数据库ASHAWR

2023-12-27 12:12:35

NumPy函数数组
点赞
收藏

51CTO技术栈公众号