分区教程参阅:http://database.9sssd.com/mssql/art/951

切换分区(归档):http://technet.microsoft.com/zh-cn/library/ms191160(v=sql.105).aspx

 

补充:

  1. 数据更新时,会根据分区依据,数据在文件组间移动
  2. 归档时,外键约束将阻止归档(同文件组的不同表间归档)

 

理想方案:正常分区,定期结转

 

USE
[master]

GO

CREATE
DATABASE
Sales
ON
PRIMARY

(

NAME=N'Sales',

FILENAME=N'd:\temp\data\Primary\Sales.mdf',

SIZE=3MB,

MAXSIZE=100MB,

FILEGROWTH=10%

),
FILEGROUP
FG1

    (

     NAME
=
N'File1',

     FILENAME
=
N'd:\temp\data\FG1\File1.ndf',

     SIZE
= 1MB,

     MAXSIZE
= 100MB,

     FILEGROWTH
= 10%

    ),
FILEGROUP
FG2

    (

     NAME
=
N'File2',

     FILENAME
=
N'd:\temp\data\FG2\File2.ndf',

     SIZE
= 1MB,

     MAXSIZE
= 100MB,

     FILEGROWTH
= 10%

    ),
FILEGROUP
FG3

    (

     NAME
=
N'File3',

     FILENAME
=
N'd:\temp\data\FG3\File3.ndf',

     SIZE
= 1MB,

     MAXSIZE
= 100MB,

     FILEGROWTH
= 10%

    )
LOG
ON

    (

     NAME
=
N'Sales_Log',

     FILENAME
=
N'd:\temp\data\Primary\Sales_Log.ldf',

     SIZE
= 1MB,

     MAXSIZE
= 100MB,

     FILEGROWTH
= 10%

    )

    GO

 

USE
sales

GO

 

CREATE
PARTITION
FUNCTION
pf_OrderDate
(DATETIME)

AS
RANGE
RIGHT

FOR
VALUES ('2003/01/01', '2004/01/01')

    GO

    

CREATE
PARTITION
SCHEME
ps_OrderDate

AS
PARTITION
pf_OrderDate

TO(FG1,FG2,FG3)

    GO

    
 

    

CREATE
TABLE
Orders

(

OrderID
INT
IDENTITY(10000, 1)
,

OrderDate
DATETIME
NOT
NULL
,

CustomerID
INT
NOT
NULL
,

CONSTRAINT
PK_Orders
PRIMARY
KEY (
OrderID, OrderDate
)

)

ON
ps_OrderDate(OrderDate)

    GO

CREATE
TABLE
OrdersHistory

(

OrderID
INT
IDENTITY(10000, 1)
,

OrderDate
DATETIME
NOT
NULL
,

CustomerID
INT
NOT
NULL
,

CONSTRAINT
PK_OrdersHistory
PRIMARY
KEY (
OrderID, OrderDate
)

)

ON
ps_OrderDate(OrderDate)

    GO

    

    

INSERT
INTO
dbo.Orders

(
OrderDate, CustomerID
)

VALUES (
'2002/6/25', 1000 )

INSERT
INTO
dbo.Orders

(
OrderDate, CustomerID
)

VALUES (
'2002/8/13', 1000 )

INSERT
INTO
dbo.Orders

(
OrderDate, CustomerID
)

VALUES (
'2002/8/25', 1000 )

INSERT
INTO
dbo.Orders

(
OrderDate, CustomerID
)

VALUES (
'2002/9/23', 1000 )

    GO

 

INSERT
INTO
dbo.Orders

(
OrderDate, CustomerID
)

VALUES (
'2003/6/25', 1000 )

INSERT
INTO
dbo.Orders

(
OrderDate, CustomerID
)

VALUES (
'2003/8/13', 1000 )

INSERT
INTO
dbo.Orders

(
OrderDate, CustomerID
)

VALUES (
'2003/8/25', 1000 )

INSERT
INTO
dbo.Orders

(
OrderDate, CustomerID
)

VALUES (
'2003/9/23', 1000 )

    GO

    

SELECT
*

FROM
dbo.Orders

WHERE
$partition.pf_orderdate(orderdate)
= 1

SELECT
*

FROM
dbo.Orders

PRINT
N'数据更新后,分区变化'

UPDATE
dbo.Orders

SET
OrderDate
=
'2004-9-8'

WHERE
OrderID
= 10000

    

SELECT
*

FROM
dbo.Orders

WHERE
$partition.pf_orderdate(orderdate)
= 1

SELECT
*

FROM
dbo.Orders

 

PRINT
N'数据归档,外键阻止归档'

CREATE
TABLE
Customer
(
id INT
PRIMARY
KEY
)

INSERT
INTO
customer

VALUES ( 1000 )

ALTER
TABLE
orders
ADD
CONSTRAINT
fk_orders_customer
FOREIGN
KEY (customerid)
REFERENCES Customer
(id)

 

CREATE
TABLE
order_detail

(

id
INT
,

ORDERid
INT
,

order_date
DATETIME
,

CONSTRAINT
PK_Orders_detail
PRIMARY
KEY (
ORDERid, Order_Date
)
,

CONSTRAINT
fk_order
FOREIGN
KEY (
ORDERid, order_date
) REFERENCES
dbo.Orders
(
OrderID, OrderDate
)

)

 

INSERT
INTO
order_detail

VALUES ( 1, 10000,
'2004/9/8'
)

 

 

ALTER
TABLE
orders
SWITCH
PARTITION 2 TO
ordersHistory
PARTITION 2

GO

/*

消息4967,级别16,状态1,第1 行

ALTER TABLE SWITCH 语句失败。由于源表'Sales.dbo.orders' 包含约束'fk_order' 的主键,因此不允许使用SWITCH。

 

*/

SELECT
*

FROM
dbo.Orders

WHERE
$partition.pf_orderdate(orderdate)
= 1

SELECT
*

FROM
dbo.Orders

SQL Server 分区表补充说明的更多相关文章

  1. SQL SERVER分区表

    简介 分区表是在SQL SERVER2005之后的版本引入的特性.这个特性允许把逻辑上的一个表在物理上分为很多部分.而对于SQL SERVER2005之前版本,所谓的分区表仅仅是分布式视图,也就是多个 ...

  2. SQL Server ->> 分区表上创建唯一分区索引

    今天在读<Oracle高级SQL编程>这本书的时候,在关于Oracle的全局索引的章节里面有一段讲到如果对一张分区表创建一条唯一索引,而索引本身也是分区的,那就必须把分区列也加入到索引列表 ...

  3. SQL Server分区表,能否按照多个列作为分区函数的分区依据(转载)

    问: Hi, I have a table workcachedetail with 40 million rows which has 8 columns.We decided to partiti ...

  4. SQL Server 分区表

    分区表可以提高查询效率 但是如果是分区表的话,表数据就会按照你指定的规则分放到不同的文件里,把一个大的数据文件拆分为多个小文件,还可以把这些小文件放在不同的磁盘下由多个cpu进行处理.这样文件的大小随 ...

  5. SQL Server 分区表的创建方法与管理

    背景知识: 分区表.可以把表中的数据按范围保存到不同的文件组中. 举个例子吧: 2014年以前的数据保存到文件组A 2014~2015的数据保存到文件组B 2015年以后的数据保存到文件组C 好处: ...

  6. SQL Server 分区表上建立ColumnStore Index 如何添加新分区方法与步骤

    在生产环境中会遇到这样的场景,一个表随着时间的推移,越来越大,这个时候我们开始动手为这个表建立分区来改进查询性能. 但是表过大上百个G的时候,在数据仓库中,为了改进查询性能,我们可以添加在分区表的基础 ...

  7. Sql Server系列:分区表操作

    1. 分区表简介 分区表在逻辑上是一个表,而物理上是多个表.从用户角度来看,分区表和普通表是一样的.使用分区表的主要目的是为改善大型表以及具有多个访问模式的表的可伸缩性和可管理性. 分区表是把数据按设 ...

  8. 玩转SQL Server复制回路の变更数据类型、未分区表转为分区表

    玩转SQL Server复制回路の变更数据类型.未分区表转为分区表 复制的应用: 初级应用:读写分离.数据库备份 高级应用:搬迁大型数据库(跨机房).变更数据类型.未分区表转为分区表 京东的复制专家 ...

  9. sql server 小记——分区表(上)

    我们知道很多事情都存在一个分治的思想,同样的道理我们也可以用到数据表上,当一个表很大很大的时候,我们就会想到将表拆 分成很多小表,查询的时候就到各个小表去查,最后进行汇总返回给调用方来加速我们的查询速 ...

随机推荐

  1. IOS 字典快速转换为Model 模型

    一般情况下IOS得局部页面加载的过程是,创建一个Model然后,将Nib文件与Model进行关联,然后能够快速的获取到Nib文件上的控件实例.操作生成页面. 但是原生的内容是没有直接通过Json获取M ...

  2. No Javascript on this page

    在调试SignalR程序时,不知怎样的情况,出现异常: HTTP Error 404.0 - Not Found The resource you are looking for has been r ...

  3. 百度云推送-服务端 C# SDK

    思路: 1.公司有项目需要做android和ios手机端推送消息的功能: 2.没有接触过这方面的知识,一头雾水,开始在网上一顿搜,网上倒是有不少解决方案,首先搜的是android的解决方案,因为ios ...

  4. MyEclipse10修改servlet模版

    Myeclipse10中servlet模版存放的位置与早些的版本不同,它存放在: MyEclipse\Common\plugins中的下面那个jar包中 com.genuitec.eclipse.wi ...

  5. serialize()序列化

  6. spring笔记4 spring MVC的基础知识4

    //todo 5,spring MVC的本地化解析,文件上传,静态资源处理,拦截器,异常处理等 spring MVC 默认使用AcceptHeaderLocalResolver,根据报文头的Accep ...

  7. Java Selenium封装--RemoteWebElement

    package com.liuke.selenium.driver; import java.sql.SQLException; import java.util.List; import org.j ...

  8. linux使用rpm重装jdk

    1.卸载jdk #rpm -qa | grep gcj 如果输出没有内容,说明没有jdk,如果输出有内容,要把搜索到的文件卸载掉,命令为: #rpm -e --nodeps [上步操作输出的文件] 然 ...

  9. Sharepoint2013:在页面上显示错误信息

    在sharepoint2013中我们需要修改以下三处的web.config,以显示错误信息 1, C:\inetpub\wwwroot\wss\VirtualDirectories\端口号\web.c ...

  10. Ionic 开发环境搭建

    android sdk环境搭建并非易事,本人经过无数失败,才使用以下方式成功 配置Ionic 开发环境 1.下载JDK并配置Java运行环境 http://www.oracle.com/technet ...