如果仅在SQL Server中创建主文件组中的所有分区,分区是否有益

Is partitioning beneficial if create all the partitions in Primary File group only in SQL Server(如果仅在SQL Server中创建主文件组中的所有分区,分区是否有益)
本文介绍了如果仅在SQL Server中创建主文件组中的所有分区,分区是否有益的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我是SQL Server新手。我正在尝试实现分区。但我有一个问题:一定要有不同的分区组吗? 或者,如果我只有一个分区组"主分区",这是默认分区组,该怎么办?在分区模式中,我只指定主文件组。

CREATE PARTITION SCHEME [Date] 
AS PARTITION [PF_FMvnt_Valuation_Date_SID] 
TO ([PRIMARY], [PRIMARY], [PRIMARY], 
    [PRIMARY], [PRIMARY], [PRIMARY], [PRIMARY], 
    [PRIMARY], [PRIMARY], [PRIMARY], [PRIMARY], 
    [PRIMARY], [PRIMARY], [PRIMARY])
GO

CREATE PARTITION FUNCTION [Date](bigint) 
AS RANGE LEFT FOR VALUES (20170228, 20170331, 20170430, 
                          20170531, 20170630, 20170731, 
                          20170831, 20170930, 20171031, 
                          20171130, 20171231, 20180131, 
                          this, 28)
通过实现此功能,我将获得12个分区,数据将填充到各自的分区中。

但这会提高并行度方面的性能吗?

如果您觉得这个问题太天真,很抱歉。

推荐答案

通常您分区有两个原因。能够一口气删除和/或添加大量数据,或者提高性能。组织可能希望将六周的当前数据保存在一个非常大的表中。每个周末,它们可能会删除最旧的分区,并为新的一周数据创建一个新的分区。因为这主要是在元数据更改时完成的,所以可以在几秒钟内删除和/或添加分区的数据(可能是10-20 GB的数据)。

第二个原因是将数据放在单独的物理卷上。因此,如果您正在搜索特定的一周,则只搜索该周的数据。如果您将整个表放在一个卷上(因此在一个驱动器或一组驱动器上),您不会在搜索方面获得很大的性能改进,但您可能会发现添加和/或删除分区非常快。

这篇关于如果仅在SQL Server中创建主文件组中的所有分区,分区是否有益的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Execute complex raw SQL query in EF6(在EF6中执行复杂的原始SQL查询)
SSIS: Model design issue causing duplications - can two fact tables be connected?(SSIS:模型设计问题导致重复-两个事实表可以连接吗?)
SQL/MySQL: split a quantity value into multiple rows by date(SQL/MySQL:按日期将数量值拆分为多行)
SQL Server Graph Database - shortest path using multiple edge types(SQL Server图形数据库-使用多种边类型的最短路径)
Invalid column name when using EF Core filtered includes(使用EF核心过滤包括时无效的列名)
How should make faster SQL Server filtering procedure with many parameters(如何让多参数的SQL Server过滤程序更快)