分区教程参阅: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. .NET Core配置文件加载与DI注入配置数据

    .NET Core配置文件 在以前.NET中配置文件都是以App.config / Web.config等XML格式的配置文件,而.NET Core中建议使用以JSON为格式的配置文件,因为使用起来更 ...

  2. JQuery 快速入门一篇通

    JQuery是什么? JQuery 是一套JavaScript库, 使用它,可以很方便的进行 JavaScript的编程.比如: 获取页面元素, 修改页面元素的CSS样式等等都可以以很简单的语法完成. ...

  3. c#使用WebClient登录网站抓取登录后的网页

    C#登录网站实际上就是模拟浏览器提交表单,然后记录浏览器响应返回的会话Cookie值,再次发送请求时带着这个会话cookie值去请求就可以实现模拟登录的效果了. 如下类CookieAwareWebCl ...

  4. iOS 阶段学习第十天笔记(结构体)

    iOS学习(C语言)知识点整理 一.数据结构 1)概念:数据结构是指计算机程序中所操作的对象——数据以及数据元素之间的相互关系和运算. 2)结构体必须有struct 关键字修饰. 实例代码: stru ...

  5. 孙鑫MFC学习笔记5:文本显示

    1.CreateSolidCaret添加一个插入符 参数:宽度,高度 如果设为0,就设为默认窗口边界的宽度和高度 2.GetSystemMetrics获取默认窗口边界的宽度和高度 3.Caret在创建 ...

  6. 框架SpringMVC笔记系列 二 传值

    主题:SpringMVC(第一节中再回顾复习一次) 学习资料参考网址: 1.http://www.icoolxue.com 2.http://haohaoxuexi.iteye.com/blog/13 ...

  7. sql 2000 关于用户权限以及sp3问题的排查

    今天在服务器上布置项目的时候tomcat启动报错,说是没有读取数据库的权限,于是开始查看自己的代码,结果发现代码中的数据库配置是正确的,于是开始找数据库本身的问题,当查看权限的时候本人新开的账户没有读 ...

  8. linux 下运行多个tomcat

    首先把tomcat解压到linux 文件夹下:如/usr/local下 #vi(gedit) /etc/profile 在其中加入 ##########first tomcat########### ...

  9. nodejs中全局变量

    1.global 类似于客户端javascript运行环境中的window module1.js: module.exports={}; //耻辱的使用了全局变量 global.varA = &quo ...

  10. php 相关模块备忘

    在安装php的时候,不管是编译安装: ./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc -- ...