SQL Server数据库自动化管理分区设计方案图解

数据库 SQL Server 自动化
本文主要介绍了SQL Server数据库自动化管理的设计方案,通过图解的形式介绍了分区的原理,并通过实例加以验证。希望能对读者有所帮助。

SQL Server数据库可以自动化管理分区,本文就以图解的形式介绍了SQL Server数据库的自动化管理分区的设计方案,接下来我们就开始介绍这一部分内容。

一、设计说明

设计这个自动化的目的是想要交替、重复地使用固定的几个分区(分区编号01~05)来保存数据,当***一个分区就是快满的时候,我们会把最旧数据的分区的数据清空出分区,新数据就可以使用老分区空间了。

应用这个自动化管理分区的环境是有些限制的,其一:分区的数据是呈现递增的,比如分区字段是自增Id值,或者是以日期作为分区;其二:可以接受历史数据被移除分区表带来的问题。其三:一天进库的数量不应大于分区管理表PartitionManage中Part_Value与Change_Value的差,因为我们作业执行的频率是1天,不过你可以调整Change_Value或者作业的执行频率。

二、看图说话

SQL Server数据库自动化管理分区设计方案图解

(图1:整体概念图)

数据流经过分区方案,被分配到不同的分区中,从图中可以看出,分区是可以重复利用的,后台有一个所谓的自动化切换分区的作业在跑,目的就是如果重复利用这些分区。这里的PRIMARY目的就是说明它与其它文件组的一个平级关系,而且我们在做交换分区时候也会用到PRIMARY,需要事先分配足够的空间。

SQL Server数据库自动化管理分区设计方案图解

(图2:自动化设计图)

这是自动化切换分区作业的逻辑处理,其中分区管理表的设计是比较重要的,它的灵活度关系到整个自动化的效果; 这个逻辑有以下几个特点:

1. 分区的索引进行存储位置对齐;其它索引在创建时就使用了分区方案,索引数据跟随分区数据一起存储在分区中;

2. 分区管理表,包含了分区记录数预警设计,在Id达到这个值后就会进行交换分区;

3. 分区管理表,FileGroup_String字段的数据可以通过SQL脚本自动化生成,条件就是分区文件组名称需要有规律;

4. 临时表是创建在PRIMARY主分区上,跟原表使用相同的分区方案;需要事先给PRIMARY分配大于或者等于一个分区文件大小的空间,这样在交换分区的时候就不用增量为主分区分配数据空间;

5. 交换旧数据到临时表,使用下面的语句可以把数据交换到相同的分区中编号,这样可以应对临时表就是一个历史表,而好处就是历史表也同样使用了分区。

 

  1. ALTER TABLE [tb] SWITCH PARTITION @PARTITION_num TO [Temp_tb] PARTITION @PARTITION_num 

 

6. 这里需要先修改分区方案,才能修改分区函数,这个跟创建分区函数与分区方案的顺序是刚好相反的。

SQL Server数据库自动化管理分区设计方案图解

(图3:分区管理表PartitionManage)

字段说明:Change_Value(预警Id值)Part_Value(分区函数值)FileGroup_String(分区文件组名称)IsDone(状态)UpdateTime(更新时间);

这就是那个分区管理表(PartitionManage),它是经过了几个版本后才把字段确定下来的,现在它已经比较完善了,能应对比较多的情况:

1. 比如我们可以修改预警值(Change_Value),让数据提早进入交换分区;

2. 比如我们可以修改分区值(Part_Value),达到调整分区间隔的目的;

3. 比如我们可以修改分区文件组名称(FileGroup_String),达到跳级文件组的目的;通过修改分区管理表来设置分区值与分区文件组的对应关系;

4. 再比如,我们一次性修改了分区方案和分区函数,已经去到很后面的分区值了,那么我们只要设置这些分区值的状态(IsDone)为1(True)就可以解决了。

5. 记录了进行交换分区的时间(UpdateTime),方便查询;

SQL Server数据库自动化管理分区设计方案图解

(图4:分区为Id字段的记录分布图)

这是一个实战中的分区情况,这样的分区特点就是分区里面的记录数基本上是持平的,在Partition_num=20的记录中明显多了很多记录,这就是因为我们没有及时进行交换分区造成的。

SQL Server数据库自动化管理分区设计方案图解

(图5:分区为ClassId(分类)字段的记录分布图)

这同样是另外一个生产环境中的真实数据,这个分区方式的特点就是分区的记录数不太均等,而我们前期需要做的就是通过划分每个分区中ClassId的值来尽量均衡分区中的记录数,所以可以看到最小与***值跨度区别是比较大。

关于SQL Server数据库自动化管理分区的设计方案就介绍到这里,如果想了解更多关于SQL Server数据库的知识,可以看一下这里的文章:http://database.51cto.com/sqlserver/,您的收获就是对我们工作***的肯定!

【编辑推荐】

  1. 共享database独立Schema构建SAAS平台
  2. Oracle跟踪文件分析工具TKPROF使用简介
  3. 误删SQL Server日志文件后怎样附加数据库
  4. 环境变量导致ASP.Net无法连接Oracle的一个案例
  5. 浅析SQL Server数据库专用管理员连接DAC的使用
责任编辑:赵鹏 来源: 博客园
相关推荐

2011-04-18 10:13:15

SQL Server 自动化表分区

2011-03-21 10:13:31

Sql Server数分区

2009-04-16 17:14:52

2009-04-22 09:42:07

SQL Server监视镜像

2011-03-15 17:13:49

SQL Server 自动化数据采集

2011-04-01 15:27:44

SQL Server数

2011-03-29 09:15:20

原始分区SQL Server数

2014-08-29 10:24:05

SQL Server

2010-07-15 17:28:50

SQL Server

2011-04-18 10:00:32

SQL Server数据库迁移

2010-07-22 11:17:52

SQL Server数

2011-03-31 14:33:57

SQL Server最小宕机迁移

2017-01-17 15:14:49

MySQL数据库自动化

2010-09-10 13:37:30

表分区SQL Server

2011-07-20 16:03:06

SQL Server数分区表

2011-04-01 15:07:29

数据库自动化

2011-07-07 09:40:05

SQL Server虚拟化数据库

2010-06-30 16:48:19

SQL Server数

2011-08-30 16:52:22

IP访问SQL Ser

2011-08-02 10:10:46

点赞
收藏

51CTO技术栈公众号