MSSQL表分区的创建详细讲解过程

php中文网
发布: 2016-06-07 17:48:21
原创
1991人浏览过

现在基本所有数据库都存在表分区的概念,但MSSQL表分区一些细节又不一样,我现在也是有一定的了解,因此本篇文章不做很细的原理性质的讲解,主要讲一下MSSQL表分区的创建过程。

首先创建新的文件,分别放到我本机的d:sppartition文件夹下的firstpart,secondpart,thirdpart文件夹,新建3个文件文件分别对应3个文件组,以我本机中存在的数据库centermy为例子,它现在有个表testsp,这是一个用户表,现在测试数据只有1000多条数据,创建代码如下:

 代码如下 复制代码

ALTER DATABASE CenterMy

ADD FILEGROUP FGSP1

GO

ALTER DATABASE CenterMy

    ADD FILE

    (

    NAME = 'SPTestLevel1',

    FILENAME = 'D:SPPartitionFirstPartSPTestLevel1.ndf',

        SIZE = 5120 KB,

        MAXSIZE = UNLIMITED,

        FILEGROWTH = 5120 KB

    ) TO FILEGROUP FGSP1

GO

创建文件组FSSP1,默认起始大小5M,最大文件数据不限制,根据实际数量大小文件以5M递增,下面创建的文件一样以这样的配置创建,文件组添加对应一个数据库文件SPTestLevel1.ndf。

 代码如下 复制代码

ALTER DATABASE CenterMy

ADD FILEGROUP FGSP2

GO

ALTER DATABASE CenterMy

    ADD FILE

    (

    NAME = 'SPTestLevel2',

    FILENAME = 'D:SPPartitionSecondPartSPTestLevel2.ndf',

        SIZE = 5120 KB,

        MAXSIZE = UNLIMITED,

        FILEGROWTH = 5120 KB

    ) TO FILEGROUP FGSP2

GO

创建文件组FSSP2,添加对应一个数据库文件SPTestLevel2.ndf。

 

 代码如下 复制代码

ALTER DATABASE CenterMy

ADD FILEGROUP FGSP3

GO

ALTER DATABASE CenterMy

    ADD FILE

    (

    NAME = 'SPTestLevel3',

    FILENAME = 'D:SPPartitionThirdPartSPTestLevel3.ndf',

        SIZE = 5120 KB,

        MAXSIZE = UNLIMITED,

        FILEGROWTH = 5120 KB

    ) TO FILEGROUP FGSP3

GO

创建文件组FSSP3,添加对应一个数据库文件SPTestLevel3.ndf。

 

查询当前数据库CenterMy的分组:

 代码如下 复制代码

SELECT *

FROM sys.filegrou

可以看到已经有4个分组了,因为默认有PRIMARY主文件组。

查看当前数据文件:

 代码如下 复制代码

SELECT *

FROM sys.database_files

可以分别看到数据文件所在目录。

 

下面创建分区函数,它将为分区中数据分布制定标准。

 代码如下 复制代码

CREATE PARTITION FUNCTION TestSPFunction (INT)

AS RANGE RIGHT FOR VALUES ( 500, 1000,1300)

GO

这里Range定义的范围可以是RIGHT或LEFT,我们这里使用的范围是RIGHT,RIGHT表明是=,LEFT表明是。即=500并且=1000并且=1300是一个分区,这里相当于分了4个段的分区。


然后创建分区方案,它将创建的分区函数映射到文件组,文件组对应磁盘上的物理数据库文件。

 代码如下 复制代码

CREATE PARTITION SCHEME TestSPScheme

AS PARTITION TestSPFunction

TO ([PRIMARY], FGSP1, FGSP2,FGSP3 )

GO

这里把分区函数的4个段对应到4个文件组上。
然后把表链接到分区方案,这里使用SPNO主键作为分区列。

 ALTER TABLE TestSP add CONSTRAINT [PK_SPNO] PRIMARY KEY CLUSTERED (SPNo)  

 ON TestSPScheme(SPNo)  

 

通过上面的操作,表分区就创建好了,并且数据自动放到相应的分区中了,下面我们查询下各个分区对应的数据量。

*

FROM sys.partitions

WHERE OBJECT_NAME(OBJECT_ID)='TestSP'

可以看到主分区有467条记录,partion_number的1,2,3,4分别对应不同文件组对应的row数据条数。

最后查询表的时候,可以在完全不知道表分区的情况下查询,我们查看下数据对应的所在分区:

SELECT *, $PARTITION.TestSPFunction(SPNo)

 FROM TestSP

发现SPNO为500的正好在第二个分区了,证明我们创建表分区成功了!

上面只是简单描述了下表分区的过程,MSSQL2008还新增了可视化界面来添加表分区,如图:

 

本文主要是展现了分区的过程,对于实际项目中,是否需要分区,怎么分区,分区部署到什么磁盘上,分区后索引创建以及是否能达到优化的效果,还需要再根据实际情况更多的考虑,

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号