手把手教你建立SQL数据库的表分区

数据库 SQL Server
分区存储提高了数据库的性能,被分区存储的数据物理上是多个文件,但逻辑上任然是一个表,对表的任何操作都跟没分区之前一样。插入、删除、查询、更新等操作的时候,数据库会自动为你找到对应的分区,然后执行操作。另外的话 把多个数据文件、日志文件都分别部署在不同的高性能物理盘上,也能大大提高性能.

1)新建一个数据库

 

2)添加几个文件组

3)回到“常规”选项卡,添加数据库文件

看到用红色框框起来的地方没?上一步中建立的文件组在这里就用上了。再看后面的路径,我把每一个文件都单独放在不同的磁盘上,而且***都是单独的放在不同的物理盘上,这样会大大提高数据的性能。 点击“确定”数据库就算创建完成了。

4)接下来要做的是建立一个分区行数,SQL语句如下:大家学习的时候***不要直接COPY,动手把它抄一遍也好。

  1. create partition function PartFuncForExample(Datetime)  
  2. as Range Right for Value('20000101','20010101','20020101','20030101'

这里我准备用表中的某个时间字段作为分区的条件,当然你也可以用其他的,比如INT之类,只要好分段的都可以。

这里注意 Right 关键字,意思就是当记录的时间(在下面会被指到表的某个字段)大于等于20000101的时候,数据会被分到下一个区间,比如2000年1月1号之前的数据会被分到一区,包含2000年1月1号和之后的数据会被分到二区,以此类推。Right 也可以使用Left替代,意思同上类似。另外,上面我定义了四个分割点,这四个分割点是根据我们刚刚创建的文件组来决定的。四个分割点就能产生5个区间段,我们把每个区间段的数据存入一个文件组。

正确执行上述语句后你可以在数据里找到以“PartFuncForExample”命名的分区函数,如下图

5)把分区函数建立好以后,我们再来建立分区方案。目的是为了把分区函数产生的分区映射到文件数据组里。分区函数是告诉数据库如何分区数据,而分区方案是告诉数据库如何把已分区的数据存到哪个文件组里。

下面我来创建分区方案。

  1. Create Partition Scheme PartSchForExample //创建一个分区方案+分区方案名称  
  2. As Partition PartFuncForExample      //目的为了 分区函数PartFuncForExample  
  3. To 
  4. (  
  5. PRIMARY, //文件组名  
  6. Partition1, //文件组名  
  7. Partition2, //文件组名  
  8. Partition3, //文件组名  
  9. Partition4 //文件组名  

正确执行后能在分区方案中看到,如下图

6)马上就快要大公告成了,下面我们来建立要分区存储的表,该表的数据理论上应该是非常非常多的,***别的记录以上而且基本上是不更新的。要不然建立分区存储就没多大意义了。

  1. Create Table PartitionTable(  
  2. [ID] [int] Identity(1,1) not null,  
  3. [Name] [nvarchar](50) not null,  
  4. [LoginDate] [DateTime] not null //用来进行分区  
  5. On PartSchForExample([LoginDate]) //上面提到的指定分区字段就是这里指定的了。 

执行这段SQL,没报错的话就大功告成了,呵呵.

总结:

分区存储提高了数据库的性能,被分区存储的数据物理上是多个文件,但逻辑上任然是一个表,对表的任何操作都跟没分区之前一样。插入、删除、查询、更新等操作的时候,数据库会自动为你找到对应的分区,然后执行操作。另外的话 把多个数据文件、日志文件都分别部署在不同的高性能物理盘上,也能大大提高性能.

当然,分区存储的好处还有很多我不知道的,欢迎高手们踊跃跟帖赐教,有错误的地方也欢迎踊跃拍砖!

---存在即是合理---

原文链接:http://www.cnblogs.com/beachant/archive/2011/06/24/2089046.html

【编辑推荐】

  1. 说说Top子句对查询计划的影响
  2. SQL Server复灾 你懂了吗?
  3. SQL Server管理 这些你懂吗?
  4. 用一句SQL解决SQL中断号问题
  5. 谈谈Java调用SQL Server分页存储过程
责任编辑:艾婧 来源: 沙滩蚂蚁的博客
相关推荐

2020-11-27 07:38:43

MongoDB

2016-04-27 09:49:16

用户模型产品总结

2011-02-22 13:46:27

微软SQL.NET

2009-04-22 09:17:19

LINQSQL基础

2020-08-12 07:41:39

SQL 优化语句

2011-06-28 14:02:49

表分区

2022-05-26 07:41:24

2011-01-10 14:41:26

2011-05-03 15:59:00

黑盒打印机

2021-07-14 09:00:00

JavaFX开发应用

2010-08-09 09:25:23

SQL Server镜

2021-09-30 18:27:38

数据仓库ETL

2017-09-05 13:01:11

CocoaPods开源库GitHub

2022-07-14 07:34:26

windowsmysqlcentos

2021-02-04 09:00:57

SQLDjango原生

2021-09-26 16:08:23

CC++clang_forma

2017-05-18 12:45:35

数据分析数据理解数据

2021-02-26 11:54:38

MyBatis 插件接口

2021-12-28 08:38:26

Linux 中断唤醒系统Linux 系统

2011-04-21 10:32:44

MySQL双机同步
点赞
收藏

51CTO技术栈公众号