SQL Server 分区表补充说明
分区教程参阅:http://database.9sssd.com/mssql/art/951
切换分区(归档):http://technet.microsoft.com/zh-cn/library/ms191160(v=sql.105).aspx
补充:
- 数据更新时,会根据分区依据,数据在文件组间移动
- 归档时,外键约束将阻止归档(同文件组的不同表间归档)
理想方案:正常分区,定期结转
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 分区表补充说明的更多相关文章
- SQL SERVER分区表
简介 分区表是在SQL SERVER2005之后的版本引入的特性.这个特性允许把逻辑上的一个表在物理上分为很多部分.而对于SQL SERVER2005之前版本,所谓的分区表仅仅是分布式视图,也就是多个 ...
- SQL Server ->> 分区表上创建唯一分区索引
今天在读<Oracle高级SQL编程>这本书的时候,在关于Oracle的全局索引的章节里面有一段讲到如果对一张分区表创建一条唯一索引,而索引本身也是分区的,那就必须把分区列也加入到索引列表 ...
- SQL Server分区表,能否按照多个列作为分区函数的分区依据(转载)
问: Hi, I have a table workcachedetail with 40 million rows which has 8 columns.We decided to partiti ...
- SQL Server 分区表
分区表可以提高查询效率 但是如果是分区表的话,表数据就会按照你指定的规则分放到不同的文件里,把一个大的数据文件拆分为多个小文件,还可以把这些小文件放在不同的磁盘下由多个cpu进行处理.这样文件的大小随 ...
- SQL Server 分区表的创建方法与管理
背景知识: 分区表.可以把表中的数据按范围保存到不同的文件组中. 举个例子吧: 2014年以前的数据保存到文件组A 2014~2015的数据保存到文件组B 2015年以后的数据保存到文件组C 好处: ...
- SQL Server 分区表上建立ColumnStore Index 如何添加新分区方法与步骤
在生产环境中会遇到这样的场景,一个表随着时间的推移,越来越大,这个时候我们开始动手为这个表建立分区来改进查询性能. 但是表过大上百个G的时候,在数据仓库中,为了改进查询性能,我们可以添加在分区表的基础 ...
- Sql Server系列:分区表操作
1. 分区表简介 分区表在逻辑上是一个表,而物理上是多个表.从用户角度来看,分区表和普通表是一样的.使用分区表的主要目的是为改善大型表以及具有多个访问模式的表的可伸缩性和可管理性. 分区表是把数据按设 ...
- 玩转SQL Server复制回路の变更数据类型、未分区表转为分区表
玩转SQL Server复制回路の变更数据类型.未分区表转为分区表 复制的应用: 初级应用:读写分离.数据库备份 高级应用:搬迁大型数据库(跨机房).变更数据类型.未分区表转为分区表 京东的复制专家 ...
- sql server 小记——分区表(上)
我们知道很多事情都存在一个分治的思想,同样的道理我们也可以用到数据表上,当一个表很大很大的时候,我们就会想到将表拆 分成很多小表,查询的时候就到各个小表去查,最后进行汇总返回给调用方来加速我们的查询速 ...
随机推荐
- Node.js系列基础学习----安装,实现Hello World, REPL
Node.js基础学习 简介 简单的说 Node.js 就是运行在服务端的 JavaScript.Node.js 是一个基于Chrome JavaScript 运行时建立的一个平台.Node.js是一 ...
- 从客户端中检测到有潜在危险的 Request.Form 值 --MVC
可以在处理Post方法的Action添加一个特性: [ValidateInput(false)],这样处理就更加有针对性,提高页面的安全性. 如: [HttpPost][ValidateInput(f ...
- UITextView 文本垂直居中
var center=textView.Bounds.Size.Height - textView.ContentSize.Height; center = center < ? : cente ...
- java.lang.IllegalStateException: Failed to read Class-Path attribute from manifest of jar file:/XXX
出现这个问题的解决方案就是将原有的jar删除 然后重新下载过一遍就可以使用了 我估计是元数据等损坏了
- JVM简介
关于java的JVM这块儿知识,在项目做大之后,一些性能的优化,要涉及到数据库,一些缓存要放在内存中.还有一些JMS的消息传播等等,高大上的知识需要有JVM内存模型知识的支持.所以自问自答,来回答下面 ...
- IT男常用软件网站整理
1. 猎豹免费WiFI. 属于wifi共享软件. 360免费wifi.. 2. 悟空VPN, 免费VPN.http://www.wkdaili.net/ 3. PLSQL. 4. WinSCP, ...
- Scalaz(11)- Monad:你存在的意义
前面提到了scalaz是个函数式编程(FP)工具库.它提供了许多新的数据类型.拓展的标准类型及完整的一套typeclass来支持scala语言的函数式编程模式.我们知道:对于任何类型,我们只需要实现这 ...
- poj-1703-Find them, Catch them
Find them, Catch them Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 41928 Accepted: ...
- oracle linux 启动
[oracle@dg1 ~]$ sqlplus /nolog SQL*Plus: Release 10.2.0.1.0 - Production on Mon May 11 12:51:24 2009 ...
- Spring MVC处理异常的4种方式
http://blog.csdn.net/ufo2910628/article/details/40399539 http://my.oschina.net/CandyDesire/blog/3333 ...