sqlserver 2008表分区操作

表分区操作步骤

1、设计表进行分区的方案,水平分区、垂直分区

       a、水平切割将减少表的行数,这样可以将历史数据归档,减少表大小,提高访问速度。

       b、垂直切割将分为主表和从表方式,将主要的列字段存放在主表中,次要的列字段存放在从表中,减少对不必要字段的访问和存放,只在需要的时候进行联表查询

2、根据业务规则确定按照日期或其他的分区原则选择分区列

3、根据选择的分区列,确定分区数,创建对应的文件组和数据文件数

      最好一个分区对应一个文件组和一个数据文件,分区数据文件最好分布在不同的磁盘上,这样有利于数据库并行操作,特别是多核cpu对I/O的访问

4、创建分区函数

      参见下面说明

5、创建分区架构

      参见下面说明

6、创建分区表

      参见下面说明

7、创建分区索引,分区聚集唯一索引

       a、分区索引可以使用不同的分区架构,但必须使用相同的分区函数,存储在不同的文件组中,但是这样讲导致索引与数据表无法对齐。

       b、建议尽量使用相同的分区架构,确保索引和数据表对齐,这样特别有利于滑动窗口方式的查询操作。

       c、大型的分区表要有唯一聚集索引或唯一索引

             唯一索引必须包含分区列,这样才能让sqlserver只访问需要的分区


表分区与分表操作的区别

  • 在sqlserver 2005之前,只能使用分表方式进行分区操作,将大表拆分成多个小表,然后通过union 方式拼接成一个视图。这种方式将给开发人员新增工作量。当需要插入更新表记录时,需要查找记录所在的数据表。
  • 在sqlserver 2005之后,微软提供表分区操作,将大表拆分成多个实际小表,大表变成逻辑表,对开发人员而言操作逻辑表与原来大表是一样的,不受影响。


创建表分区架构

 

CREATE PARTITION SCHEME [Sln_Partition_Tbl_IntegeralLog]
AS PARTITION [Fn_Partition_Tbl_IntegeralLog] 
TO ([文件组名1], [文件组名2], [文件组名3])
GO

 

 

修改表分区架构


删除表分区架构

 

IF  EXISTS 
(
    SELECT * 
    FROM sys.partition_schemes WHERE name = N'Sln_Partition_Tbl_IntegeralLog'
)
DROP PARTITION SCHEME [Sln_Partition_Tbl_IntegeralLog]
GO

 

 

创建表分区函数

 

CREATE PARTITION FUNCTION [Fn_Partition_Tbl_IntegeralLog](datetime) 
AS RANGE LEFT 
FOR VALUES (N'2010-01-01T00:00:00.000', N'2011-01-01T00:00:00.000', N'2012-01-01T00:00:00.000', N'2013-01-01T00:00:00.000', N'2014-01-01T00:00:00.000')
GO

 

修改表分区函数


删除表分区函数

IF  EXISTS 
(
    SELECT * 
    FROM sys.partition_functions 
    WHERE name = N'Fn_Partition_Tbl_IntegeralLog'
)
DROP PARTITION FUNCTION [Fn_Partition_Tbl_IntegeralLog]
GO

 

查询表分区数据分布情况

 

  select  $partition.Fn_Partition_Tbl_IntegeralLog(tC_Time) [分区编号],
          count(*) [分区编号],
          min(tC_Time) [起始分界],
          max(tC_Time) [终止分界]
  from dbo.Tbl_IntegeralLog
 group by $partition.Fn_Partition_Tbl_IntegeralLog(tC_Time)


创建分区表

 

CREATE TABLE Tbl_IntegeralLog
(
    tC_Id   INT is not null,
    tC_Time datetime default getdate(),
    PRIMARY KEY (ID)
) ON Fn_Partition_Tbl_IntegeralLog(tC_Time)
GO


 

 

查询表记录分配到哪个分区中

 

SELECT *, $PARTITION.Fn_Partition_Tbl_IntegeralLog(tC_Time)
FROM Tbl_IntegeralLog


查询分区2中的记录信息

 

 

select * 
from Tbl_IntegeralLog 
where $PARTITION.Fn_Partition_Tbl_IntegeralLog([tC_Time])= 2


查询分区函数、分区边界值、分区架构

select * from sys.partition_functions
select * from sys.partition_range_values
select * from sys.partition_schemes


根据分区字段的值查询出分区号

 

 SELECT $PARTITION.Fn_Partition_Tbl_IntegeralLog('2011-01-01')

 

以下目录视图包含数据库、表和索引级别的分区信息,以及有关单个分区函数和分区方案的信息。

获取有关单个分区函数的信息

获取有关分区函数的单个参数的信息

获取有关分区函数边界值的信息

获取有关数据库中所有分区方案的信息

获取有关单个分区方案的信息

获取有关数据库中所有分区的信息

获取有关表或索引的分区信息


 

 



 

posted @ 2013-10-22 19:57  wala-wo  阅读(321)  评论(0编辑  收藏  举报