加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sqlserver 2008表分区操作

发布时间:2020-12-12 13:54:03 所属栏目:MsSql教程 来源:网络整理
导读:表分区操作步骤 1、设计表进行分区的方案,水平分区、垂直分区 ?????? a、水平切割将减少表的行数,这样可以将历史数据归档,减少表大小,提高访问速度。 ?????? b、垂直切割将分为主表和从表方式,将主要的列字段存放在主表中,次要的列字段存放在从表中,

表分区操作步骤

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')

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

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

  • sys.partition_functions (Transact-SQL)

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

  • sys.partition_parameters (Transact-SQL)

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

  • sys.partition_range_values (Transact-SQL)

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

  • sys.partition_schemes (Transact-SQL)

  • sys.data_spaces (Transact-SQL)

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

  • sys.destination_data_spaces (Transact-SQL)

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

  • sys.partitions (Transact-SQL)

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

  • sys.tables (Transact-SQL)

  • sys.indexes (Transact-SQL)

  • sys.index_columns (Transact-SQL)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读