1. 纵向分表

纵向分表是指将一个有20列的表根据列拆分成两个表一个表10列一个表11列,这样单个表的容量就会减少很多,可以提高查询的性能,并在一定程度上减少锁行,锁表带来的性能损耗。

纵向分表的原则是什么呢,应该怎样拆分呢?答案是根据业务逻辑的需要来拆分,对于一张表如果业务上分两次访问某一张表其中一部分数据,那么就可以根 据每次访问列的不同来做拆分; 另外还可以根据列更新的频率来拆分,例如某些列每天要更新3次,有些列从创建开始基本上很少更新。

举例: 假定场景,我有一张用户表,这张表包含列: ID, UserName, Password, RealName, Gender, Email, IsEmailValid, Birthday, Country, City, Address, Mobile, Phone, ZipCode, Hometown, OfficePhone, Company, Position, Industry, LatestLoginTime, LatestLoginIP, LoginTimes,OnlineMinutes

假定现在我们的登录出现了性能问题,用户登录经常出现数据库超时的现象。我们打算用拆表的方法解决这个问题。先看下涉及到登录的字段 有:UserName,Password,LatestLoginTime,LatestLoginIP,LoginTimes;那么我们就可以以此为依 据将原表拆分为:UserLogin和UserBase 两个表,后者包含除了登录信息的其他列信息;两张表都要包含主键ID。

2. 横向分区

横向分区是将表从行的角度拆分,例如将创建时间在05年之前的数据放在一个分区上,将05年到08年之间的数据放到另一个分区上,以此类推。横向分区所根据的列必须在聚集索引上,通常会根据时间,主键id等进行划分。

横向分区将数据划分为不同的区,在根据分区列条件进行查询时可以缩小查询的范围,从而提高查询的性能;另外如果数据库服务器有多个cpu,则可以通过并行操作获得更好的性能。

到底要根据那个列进行横向的分区和查询有关系,我们在建表的时候需要分析,会根据那个列进行查询。

举例: 1. 订单是一个实效性很强的实体,我们很少查询几年前的订单数据,我们就可以在订单的创建时间列上创建分区函数来做分区。 2. 比如帖子通常情况下只有在首页推荐的最新的帖子被访问次数很多,而几年前的帖子被访问的几率较小,这时候我们可以根据帖子的主键id来做分区,id小于 300w的在一个分区上,id在300到600w之间的在一个分区上。

转载于:https://www.cnblogs.com/tonykan/archive/2013/05/18/3084918.html

sql分区-纵向分表与横向分区表(转)相关推荐

  1. mysql 横向分表_mysql横向和纵向的数据库分表

    分表是分散数据库压力的好方法. 分表,最直白的意思,就是将一个表结构分为多个表,然后,可以再同一个库里,也可以放到不同的库. 当然,首先要知道什么情况下,才需要分表.个人觉得单表记录条数达到百万到千万 ...

  2. 数据库的横向和纵向分表

    1.横向分表 避免数据冗余,符合第三范式,让数据管理没有那么麻烦,但是设计的时候为了性能,可以做出妥协. 2.纵向分表 对于互联网公司来讲,数据有可能是几亿级别,如果在一个数据库的一张表中存储,数据库 ...

  3. 43 | 什么时候使用MySQL的分区表?(分区和分表是有区别的)

    一.先干一碗鸡汤 任何事情都是循序渐进的,无论自己有多期待一个好结果,都是急不来的,事压不垮人,但是情绪会压垮人. 二.干巴得的内容 2.1.分区表语法是什么?引擎中的存储结构是什么? CREATE ...

  4. 数据库分区、分表、分库、分片

    一.分区的概念 数据分区是一种物理数据库的设计技术,它的目的是为了在特定的SQL操作中减少数据读写的总量以缩减响应时间. 分区并不是生成新的数据表,而是将表的数据均衡分摊到不同的硬盘,系统或是不同服务 ...

  5. Oracle Spatial分区应用研究之一:分区与分表查询性能对比

    1.名词解释 分区:将一张大表在物理上分成多个分区,逻辑上仍然是同一个表名. 分表:将一张大表拆分成多张小表,不同表有不同的表名. 两种数据组织形式的原理图如下: 图 1分表与分区的原理图 2.实验目 ...

  6. mysql数据库表分区_MySQL数据库之MySQL的分区和分表详解

    本文主要向大家介绍了MySQL数据库之MySQL的分区和分表详解 ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助. 1. 分区 MySQL中的分区是指将一个数据表按照某种规则(如时 ...

  7. redis分表_《面试官系列:深入数据库分区分库分表》

    一.为什么要分库分表 软件时代,传统应用都有这样一个特点:访问量.数据量都比较小,单库单表都完全可以支撑整个业务.随着互联网的发展和用户规模的迅速扩大,对系统的要求也越来越高.因此传统的MySQL单库 ...

  8. mysql删除分表键_一文看懂 MySQL 分区和分表,提高表增删改查效率

    原标题:一文看懂 MySQL 分区和分表,提高表增删改查效率 作者:冯帅,精通Oracle. MySQL. 擅长异构数据库数据同步及迁移.数据库的设计和调优,对高可用方案有深入研究. MySQL分区和 ...

  9. mysql 分表和分区_Mysql分表和分区的区别

    一,什么是mysql分表,分区 什么是分表,从表面意思上看呢,就是把一张表分成N多个小表,具体请看mysql分表的3种方法 什么是分区,分区呢就是把一张表的数据分成N多个区块,这些区块可以在同一个磁盘 ...

最新文章

  1. 栈的应用_中缀表达式转后缀表达式
  2. linux deepin sudo: add-apt-repository:找不到命令 解决办法
  3. 运行keras出现 FutureWarning: Passing (type, 1) or ‘1type‘ as a synonym of type is deprecated解决办法
  4. python运行命令_Python中执行外部命令
  5. 双亲委派机制_史上三次破坏ClassLoader双亲委派机制
  6. swift 通知_Swift 闭包无脑加 [weak self] 行不行?
  7. English trip -- VC(情景课)2 C Where's my pencli?
  8. Struts2_day03--向值栈放数据
  9. java学生管理系统登录注册_《Java》— 学生管理系统——登录界面
  10. 视易linux进图形界面,视易KTV点歌机系统安装说明.ppt
  11. 软件开发人员需要记住的10个操作系统概念(译)
  12. DDR3的容量计算方法
  13. 电脑浏览器下载速度很慢怎么办
  14. 物联网常见的无线传输协议类型
  15. android绘画时钟,Android画个时钟玩玩
  16. Xenu软件检查网站死链接
  17. 联想电脑黑屏但电源键亮着的解决办法
  18. css筋斗云,CSS3 七龙珠筋斗云动画
  19. CF1592B Hemose Shopping
  20. 模式识别作业2——SYSU

热门文章

  1. 如何进入python程序代码编辑环境_Python怎么打开代码编辑器 来学习吧
  2. JZOJ 3597. 【CQOI2014】危桥
  3. JZOJ 2309. 【中山市选2011】辽哥游戏
  4. android表情输入键盘,GitHub - UKfire/Emotion: 帮你的Android应用快速集成表情键盘
  5. python 任务计划_使用Python添加计划任务
  6. python的api库_python 利用toapi库自动生成api
  7. 自动化测试工具selenium python_自动化测试工具之Selenium(一)-----Selenium的介绍以及安装...
  8. Tex2Word vs Word2Tex
  9. [JOI2012春季合宿]Rotate (链表)
  10. java限频_单个用户及Ip请求频率限制思路(附java实现)