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 小记——分区表(上)
我们知道很多事情都存在一个分治的思想,同样的道理我们也可以用到数据表上,当一个表很大很大的时候,我们就会想到将表拆 分成很多小表,查询的时候就到各个小表去查,最后进行汇总返回给调用方来加速我们的查询速 ...
随机推荐
- 30天C#基础巩固-----序列化,集合
关于集合的练习. ----->计算字符串每个字符出现的次数. Console.WriteLine("请输入?"); string input = Console.ReadLi ...
- MySQL Error Handling in Stored Procedures 2
Summary: this tutorial shows you how to use MySQL handler to handle exceptions or errors encountered ...
- 基于Typecho CMS框架开发大中型应用
基于Typecho CMS框架开发大中型应用 大中型应用暂且定义为:大于等于3个数据表的应用!汗吧! Typecho原本是一款博客系统,其框架体系有别于市面上一般意义MVC框架,主体代码以自创的Wid ...
- Appcelerator Titanium Studio: JNI_CreateJavaVM missing error
Mac升级到Yosemite后,Titanium Studio启动不了,报Appcelerator Studio: JNI_CreateJavaVM missing error 之类的错误,重装了Or ...
- ios 根据文字数量计算UILabel高度(已修改)
由于留言的朋友给出了更好的方法,所以下面的代码都是它留言中给出的,优于我前面计算Lable高度方法,这个可以说非常的准,是IOS自带的计算UILABEL高度的方式. 一.实现代码 // 创建label ...
- Ajax中传递Json格式的参数
$.ajax({ type: "post", url: baseUrl+"sys/login", dataType: "json", con ...
- 项目总结笔记系列 wsTax KT Session1
项目总结笔记 1.专有名词解释: SMO, Separate Management Office. UAT, User Accept Test. GSLB, Global Server Load B ...
- mongodb数据库备份导入导出数据
备份数据: mongodump -h 192.168.2.20 -u game -p 12345678 -d dbname -o /data/test/ --excludeCollection=use ...
- org.hibernate.NonUniqueObjectException: a different object with the same identifier value was alread---------程序报错
今天遇到了这个问题: org.hibernate.NonUniqueObjectException: a different object with the same identifier value ...
- PDF.NET框架学习篇之SQL-MAP使用存储过程
最近一直在学习“深蓝医生”的PDF.NET框架,对Sql-Map使用存储过程有了点小小的体会.基础知识请到http://www.cnblogs.com/bluedoctor/archive/2010/ ...