首先明确表分区和分库分表的概念。

  • 表分区:在不破坏原本表结构的基础上,对单个大表进行切割,分成不同文件,存储在不用文件或硬盘。
  • 分库分表:这里涉及到垂直切分及水平切分(引用网上的文章:https://www.cnblogs.com/zr520/p/5449748.html)。

垂直切分:垂直拆分就是要把表按模块划分到不同数据库表中(当然原则还是不破坏第三范式),这种拆分在大型网站的演变过程中是很常见的。当一个网站还在很小的时候,只有小量的人来开发和维护,各模块和表都在一起,当网站不断丰富和壮大的时候,也会变成多个子系统来支撑,这时就有按模块和功能把表划分出来的需求。其实,相对于垂直切分更进一步的是服务化改造,说得简单就是要把原来强耦合的系统拆分成多个弱耦合的服务,通过服务间的调用来满足业务需求看,因此表拆出来后要通过服务的形式暴露出去,而不是直接调用不同模块的表,淘宝在架构不断演变过程,最重要的一环就是服务化改造,把用户、交易、店铺、宝贝这些核心的概念抽取成独立的服务,也非常有利于进行局部的优化和治理,保障核心模块的稳定性。

水平切分:上面谈到垂直切分只是把表按模块划分到不同数据库,但没有解决单表大数据量的问题,而水平切分就是要把一个表按照某种规则把数据划分到不同表或数据库里。例如像计费系统,通过按时间来划分表就比较合适,因为系统都是处理某一时间段的数据。而像SaaS应用,通过按用户维度来划分数据比较合适,因为用户与用户之间的隔离的,一般不存在处理多个用户数据的情况,简单的按user_id范围来水平切分

这里我们指讨论表分区。

1.首先明确系统中对此表的查询情况

如果系统比较复杂可以借助“SQL Server Profiler”对生产环境进行抓取。并分析此表的查询情况,比如:如果是行业类型的新闻,可能以行业来查询的情况比较多,笔者之前维护过一个系统,属于行业资讯类,单表大概几百万,对行业ID建立索引后,列表页查询(Row_number)大概在200ms左右。利用行业ID进行表分区后,稳定表现在50ms左右。因为sqlserver优化器会根据表分区的函数定位到该分区,不对其他分区进行查询,所以提高比较明显。总的来说就是先判断要以哪个字段作为分区依据。

如果存在多个可进行分区的字段,那么如果他们之间是有关联的,比如:类别1,类别1的2级类别,类别1的3级类别,但是又是有互相关系的,可以对基础字段进行分区,及类别1。如果需要查询“类别1的2级类别”,可以把类别1加上,这样依然会定位对应的分区从而提高速度。

2.创建文件组

  • 一种利用sqlserver的管理器进行创建:

  • 利用命令进行创建,
alter database <数据库名> add filegroup <文件组名>

如果打算分10区就得添加10个文件组。

3.创建文件(真实的文件名)

alter database <数据库名称> add file <数据标识> to filegroup <文件组名称>--<数据标识> (name:文件名,fliename:物理路径文件名,size:文件初始大小kb/mb/gb/tb,filegrowth:文件自动增量kb/mb/gb/tb/%,maxsize:文件可以增加到的最大大小kb/mb/gb/tb/unlimited)

4.创建表分区

在这里设置分区的项目,PRIMARY则是默认的DB文件。一般先存储到分区,最后剩下的数据存储在PRIMARY。完成后生成脚本。

数据库Sql server 表分区相关推荐

  1. SQL Server 表分区实战系列(文章索引)

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 前言(Introduction) 实战说明(In Action) 表分区逻辑结构图(Construction) 表分区学 ...

  2. SQL Server表分区【转】

    转自:http://www.cnblogs.com/knowledgesea/p/3696912.html SQL Server表分区 什么是表分区 一般情况下,我们建立数据库表时,表数据都存放在一个 ...

  3. 52. SQL Server -- 表分区实战系列(文章索引)

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 前言(Introduction) 实战说明(In Action) 表分区逻辑结构图(Construction) 表分区学 ...

  4. SQL Server表分区-水平分区

    SQL Server表分区,sql server水平分区 转自:http://www.cnblogs.com/knowledgesea/p/3696912.html  根据时间的,直接上T-SQL代码 ...

  5. sql server表分区_介绍分区表SQL Server增量统计信息

    sql server表分区 If you are maintaining a very large database, you might be well aware of the pain to p ...

  6. sql server表分区_SQL Server 2016增强功能– SQL截断表和表分区

    sql server表分区 The idea behind this article is to discuss the importance and the implication of SQL P ...

  7. SQL Server 表分区注意事项(转载)

    在园子里看到 听风吹雨 关于SQL Server 表分区注意事项 ,总结的太好了.备忘,方便以后查询! http://www.cnblogs.com/gaizai/archive/2011/05/31 ...

  8. SQL Server表分区的NULL值问题

    原文:SQL Server表分区的NULL值问题 SQL Server表分区的NULL值问题 SQL Server表分区只支持range分区这一种类型,往往会被大家吐槽 人家MySQL支持四种类型:R ...

  9. sql server表分区_SQL Server中的FORCESCAN和分区表

    sql server表分区 I would like to share one curios case that I recently came across. 我想分享一下我最近遇到的一个古玩案例. ...

最新文章

  1. 桌面虚拟化场景中对存储系统IO性能的评估方法
  2. 如何在 Xcode 中修改应用的名字
  3. 如何搞定SVN目录的cleanup问题和lock问题
  4. luogu P1064 金明的预算方案
  5. C语言sprintf 和 sscanf函数
  6. 大数据教你实现预测未来,这不是梦
  7. 用Win XP接收传真
  8. 力扣-1128 等价多米诺骨牌对的数量
  9. idea安装2019
  10. idea 导入 android项目以及自带AVD模拟器的使用
  11. java infinite or nan,java.lang.NumberFormatException: Infinite or NaN(数学运算错
  12. React组件通信-父子组件间的通信
  13. VC 常见的108个问题[转]
  14. MATLAB将数据存在TXT文件中
  15. Word——删除最后一页空白页的方法
  16. 用事实说话,我们的数据库应选择RAID几?
  17. Spring框架知识
  18. 什么是模块化?模块化的好处
  19. Jsoup 爬取真气网排名信息
  20. 计算机无法开机 如何系统还原步骤,如何解决一键GHOST还原失败后电脑无法开机?...

热门文章

  1. 空间相关分析(二) 全局莫兰指数的理解与计算
  2. Java编程03--XML文件
  3. 解读最早的草图-图像翻译工作SketchyGAN
  4. 小程序客服消息怎么使用?小程序的消息推送有什么限制?
  5. 国防科技大学计算机非军籍研究生就业情况,国防科大“非军籍本科生”值得报考吗?非常值得!毕业就是金饭碗...
  6. Android适配多国语言规则
  7. Android SDK AVD Manager
  8. 谷歌AI专家说:你们都是瞎努力!道翰天琼认知智能机器人API接口平台为您揭秘。
  9. SpringBoot之spring.factories
  10. 天翼云从业认证(4.5)多层级高可用解决方案