最近在做项目数据库优化过程中,考虑了数据库表分区的方案,MSSQL2005新增了表分区的概念,现在我用测试表来做一次表分区。表分区可以把不同数据放到不同数据库文件,按物理地址来隔开数据,理论情况下如果服务器是多磁盘,多CPU,还做了磁盘阵列后,查询操作效率会更明显。

现在基本所有数据库都存在表分区的概念,但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:\SPPartition\FirstPart\SPTestLevel1.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:\SPPartition\SecondPart\SPTestLevel2.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:\SPPartition\ThirdPart\SPTestLevel3.ndf',

SIZE = 5120 KB,

MAXSIZE = UNLIMITED,

FILEGROWTH = 5120 KB

) TO FILEGROUP FGSP3

GO

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

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

SELECT *

FROM sys.filegroups

可以看到已经有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是一个区,>=500并且<1000是一个区,>=1000并且<1300是一个取,>=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)

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

select *

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还新增了可视化界面来添加表分区,如图:

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

转载于:https://www.cnblogs.com/Lawson/archive/2011/09/28/2194824.html

MSSQL表分区的创建相关推荐

  1. Oracle分区详解和创建,数据库优化-Oracle表分区的创建和分类

    Oracle的表分区功能通过改善可管理性.性能和可用性,从而为各式应用程序带来了极大的好处.通常,分区可以使某些查询以及维护操 当表中的数据量不断增大,查询数据的速度就会变慢,应用程序的性能就会下降, ...

  2. Oracle表分区的创建、新增、拆分

    Oracle中为了方便管理.查询数据当数据量大于500w或者2G时最好用分区表,常见的一种是使用时间作为分区. 分区表添加新的分区有 2 种情况: (1) 原分区里边界是 maxvalue 或者 de ...

  3. MySql表分区的创建与使用

    一.创建表分区 MySql默认是支持表分区的,可以通过语句查询是否开启表分区功能:show plugins : 创建表分区只需要在创建表的语句后面加上分区语句就可以,例如: create table ...

  4. mysql 删除创建表分区_创建,增加,删除mysql表分区

    1.测试添加分区和删除分区 ###添加删除range分区 (1)创建一个分区: CREATE TABLE titles ( emp_no      INT NOT NULL, title        ...

  5. Mysql表分区的选择与实践小结

    2019独角兽企业重金招聘Python工程师标准>>> 在一些系统中有时某张表会出现百万或者千万的数据量,尽管其中使用了索引,查询速度也不一定会很快.这时候可能就需要通过分库,分表, ...

  6. oracle存储过程建分区表,oracle存储过程创建表分区实例

    用存储过程创建数据表: 创建时注意必须添加authid current_user,如果创建的表已存在,存储过程继续执行,但如不不加此关键语句,存储过程将出现异常, 这个语句相当于赋权限. 例1 创建语 ...

  7. maxvalue mysql自动分区_创建mysql表分区的方法

    创建 mysql 表分区的方法 我来给大家介绍一下 mysql 表分区创建与使用吧,希望对各位同学会有所帮助.表分区的测试使用,主要内容来自 于其他博客文章以及 mysql5.1 的参考手册. 表分区 ...

  8. MYSQL定时创建表分区

    MYSQL定时创建表分区 一.存储过程-表分区 ----------------------------------------------------------------- 需求: 每月创建一个 ...

  9. ORACLE 创建表分区

    原文:https://www.cnblogs.com/yuxiaole/p/9809294.html oracle 11g 支持自动分区,不过得在创建表时就设置好分区. 如果已经存在的表需要改分区表, ...

最新文章

  1. JAVA 代码里中文乱码问题
  2. 教你辨别36k纯数据科学家
  3. ns 25的L2TP模式×××配置
  4. java Jsoup不能获取完整响应内容
  5. 对大学 IT 专业教育的反馈
  6. linux 的 usr 文件
  7. 《MySQL DBA修炼之道》——1.4 MySQL权限
  8. java 快速删除文件夹_如何用Java删除文件夹里的所有文件?
  9. pio代表什么_“PIO是什么的简称?PIO”是什么的 – 手机爱问
  10. java 传递intent_intent传递参数
  11. Open Language Tools:简介(1)
  12. prometheus实战(一) 原理介绍
  13. 服务器防火墙部分指令
  14. Python 蓝凌OA任意文件读取批量扫描 poc编写
  15. Redis伪集群搭建
  16. 微信小程序开发(4)--发布评论
  17. HaLoop—适用于迭代计算的Hadoop
  18. 入门Python400集视频,Python学会之后,一般能拿到多少工资?
  19. Druid基本概念及架构介绍
  20. Gmap.net搜集

热门文章

  1. 一款功能强大的IP查询工具
  2. 【干货】路由黑洞的5种解决方法大PK
  3. 如何选择最优路径完成云原生上云?听这场阿里云特别分享【云原生技术与最佳实践】
  4. 面向云原生的混沌工程工具-ChaosBlade
  5. android service alertdialog,Android service里面启动alertdialog
  6. 浙大计算机专业分数线,被浙江大学提前批的冷门专业录取,后悔没选计算机专业:可惜分数...
  7. 计算机组成原理验证JRNS,计算机组成原理(上)第4章 测试(中)
  8. 1、spring的IOC
  9. oracle什么是全局锁,深入浅出oracle锁---原理篇
  10. h3csnmp管理命令_H3C S5500V2-EI系列以太网交换机 命令参考-Release 1118-6W100_网络管理和监控命令参考_SNMP命令-新华三集团-H3C...