为什么80%的码农都做不了架构师?>>>   

垂直拆分

垂直拆分是指数据表列的拆分,把一张列比较多的表拆分为多张表
通常我们按以下原则进行垂直拆分:

  1. 把不常用的字段单独放在一张表;

  2. 把text,blob等大字段拆分出来放在附表中;

  3. 经常组合查询的列放在一张表中;

垂直拆分更多时候就应该在数据表设计之初就执行的步骤,然后查询的时候用jion关键起来即可;

水平拆分

水平拆分是指数据表行的拆分,表的行数超过200万行时,就会变慢,这时可以把一张的表的数据拆成多张表来存放。

水平拆分的一些技巧

1. 拆分原则 通常情况下,我们使用取模的方式来进行表的拆分;比如一张有400W的用户表users,为提高其查询效率我们把其分成4张表users1,users2,users3,users4 通过用ID取模的方法把数据分散到四张表内Id%4+1 = [1,2,3,4] 然后查询,更新,删除也是通过取模的方法来查询

$_GET['id'] = 17,
17%4 + 1 = 2,
$tableName = 'users'.'2'
Select * from users2 where id = 17;

在insert时还需要一张临时表uid_temp来提供自增的ID,该表的唯一用处就是提供自增的ID;

insert into uid_temp values(null);

得到自增的ID后,又通过取模法进行分表插入;

注意,进行水平拆分后的表,字段的列和类型和原表应该是相同的,但是要记得去掉auto_increment自增长

另外

  • 部分业务逻辑也可以通过地区,年份等字段来进行归档拆分;
  • 进行拆分后的表,只能满足部分查询的高效查询需求,这时我们就要在产品策划上,从界面上约束用户查询行为。比如我们是按年来进行归档拆分的,这个时候在页面设计上就约束用户必须要先选择年,然后才能进行查询;
  • 在做分析或者统计时,由于是自己人的需求,多点等待其实是没关系的,并且并发很低,这个时候可以用union把所有表都组合成一张视图来进行查询,然后再进行查询;
Create view users as select from users1 union select from users2 union.........

转载于:https://my.oschina.net/nbspjj/blog/748084

表的垂直拆分和水平拆分相关推荐

  1. Mysql 分表 垂直分割_图文解释 读写分离、垂直拆分、水平拆分、分库分表

    1. 前言 相信你经常被 读写分离.垂直拆分.水平拆分.分库分表 这几个名词搞得很懵逼.我有时候也很懵逼,那么今天就来把这几个数据库常用术语搞清楚,同时也记录一下. 2. 读写分离 这个相对比较好理解 ...

  2. Mycat实现垂直拆分与水平拆分

    垂直拆分(分库) 一个数据库由很多表的构成,每个表对应着不同的业务,垂直切分是指按照业务将表进行分类, 分布到不同 的数据库上面,这样也就将数据或者说压力分担到不同的库上面,如下图: 系统被切分成:用 ...

  3. 数据切分 垂直切分、垂直拆分与水平拆分的优缺点

    数据切分 垂直切分 关于数据库的水平切分和垂直切分的一些概念垂直拆分垂直拆分就是要把表按模块划分到不同数据库表中(当然原则还是不破坏第三范式),这种拆分在大型网站的演变过程中是很常见的.当一个网站还在 ...

  4. 数据库的垂直拆分和水平拆分

    2019独角兽企业重金招聘Python工程师标准>>> 当我们使用读写分离.缓存后,数据库的压力还是很大的时候,这就需要使用到数据库拆分了. 数据库拆分简单来说,就是指通过某种特定的 ...

  5. 理解分布式系统中的垂直拆分和水平拆分

    概念 水平拆分简单字面意思是:水平方向上由一个拆分为多个.垂直拆分简单字面意思是:垂直方向上由一个拆分为多个. 1,垂直拆分 垂直拆分指按照功能进行拆分,秉着"专业的人干专业的事" ...

  6. 数据库垂直拆分和水平拆分

  7. 数据库和数据库表的水平拆分和垂直拆分

    数据库垂直拆分(按照功能模块拆分) 数据库水平拆分(根据某种规则划分,比如对id取余) 数据库表的垂直拆分 数据库表的水平拆分 数据拆分前其实是要首先做准备工作的,然后才是开始数据拆分 第一步:采用分 ...

  8. SOA和微服务之间的区别(应用和数据的垂直拆分水平拆分)

    目录 引出问题 重要概念 垂直拆分 水平拆分 同步分层架构 异步分层架构 SOA是什么? 微服务是什么? 数据库拆分 写在最后 引出问题 互联网发展迅猛,互联网系统也由原来的单机服务逐步的演化为分布式 ...

  9. mysql数据库垂直切分_mysql数据库的水平拆分与垂直拆分

    近端时间在面试,发现很多面试官或者面试都把数据的水平拆分合垂直拆分给搞混了,今天特意写了一篇博客来说说水平拆分和垂直拆分希望对程序猿们有所帮助. 数据库水平与垂直拆分: 垂直(纵向)拆分:是指按功能模 ...

最新文章

  1. ZooKeeper概述
  2. Hystrix断路器(五)
  3. Flink从入门到精通100篇(二十)-跨境电商 Shopee 的实时数仓之路
  4. 某大型国企技术平台建设
  5. hibernate教程--抓取策略
  6. 解决国内NPM安装依赖速度慢问题
  7. 使用JSON的RESTful云数据库
  8. 开源中文关系抽取框架,来自浙大知识引擎实验室
  9. ironpython3发布时间_IronPython0.9.3发布了 —— 介绍一下Decorator
  10. 性能翻倍!斯坦福Matei团队推出机器学习模型优化新方法
  11. IT认证之架构师认证
  12. SPSS 独立样本t检验方法
  13. STM32串口通信程序模拟超市打印机工作-使用接收中断、空闲中断、校验中断
  14. 对待工作的态度和意识
  15. Learning Git Branching 题解(基础、高级、Git远程仓库)
  16. 虾米带你轻松搞定Vuejs 系列
  17. thymeleaf 设置时间格式
  18. 华为又招了一名天才少年!
  19. Linux命令基础入门
  20. 单目标跟踪 (一)相关滤波器 方法综述

热门文章

  1. 页面加载进度条改进版
  2. 深入学习Heritrix---解析CrawlController
  3. 脉冲神经网络_【强基固本】脉冲神经网络(SNN)
  4. oracle大量删除数据之后索引是否需要重建_oracle10g重建XDB
  5. lua如何判断是否支持cookie_如何判断家里暖气片是否需要更换
  6. iOS进阶之底层原理-block本质、block的签名、__block、如何避免循环引用
  7. SQLite中的表达式
  8. 判断密文加密类型hash-identifier
  9. python第一单元笔记_Python 初学笔记 - 第一章-列表
  10. ascii码_umask,补码,ASCII码:稍微深入考虑一点