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 小记——分区表(上)
我们知道很多事情都存在一个分治的思想,同样的道理我们也可以用到数据表上,当一个表很大很大的时候,我们就会想到将表拆 分成很多小表,查询的时候就到各个小表去查,最后进行汇总返回给调用方来加速我们的查询速 ...
随机推荐
- Git undo 操作
相比传统的版本管理工具,git 的 undo 操作也不是很简单明了,本文尝试总结常用的 undo 操作. 重新提交 应该避免考虑不周全的提交,但这太难了.因此Git 专门提供了一个命令来弥补粗心的提交 ...
- C++ - 虚基类、虚函数与纯虚函数
虚基类 在说明其作用前先看一段代码 class A{public: int iValue;}; class B:public A{public: void bPrintf(){ ...
- Android SDK Android NDK Android Studio 官方下载地址
2016.12 Android Studio Windows Includes Android SDK https://dl.google.com/dl/android/studio/install/ ...
- 在MVC中使用async和await的说明
首先,在mvc中如果要用纯异步请不要使用async和await,可以直接使用Task.Run. 其次,在mvc中使用async和await可以让系统开新线程处理Task的代码,同时不必等Task执行结 ...
- Json.Net
下载地址:Json.NET 文档地址:Json.NET Documentation 基本的序列化与反序列化 public class Product { public string Name { ge ...
- Winform开发主界面菜单的动态树形列表展示
我在之前很多文章里面,介绍过Winform主界面的开发,基本上都是标准的界面,在顶部放置工具栏,中间区域则放置多文档的内容,但是在顶部菜单比较多的时候,就需要把菜单分为几级处理,如可以在顶部菜单放置一 ...
- .net断点续传的原理
在了解HTTP断点续传的原理之前,先来说说HTTP协议,HTTP协议是一种基于tcp的简单协议,分为请求和回复两种.请求协议是由客户机(浏览器)向服务器(WEB SERVER)提交请求时发送报文的协议 ...
- AspectJ对AOP的实现
一:你应该明白的知识 1.对于AOP这种编程思想,很多框架都进行了实现.Spring就是其中之一,可以完成面向切面编程.然而,AspectJ也实现了AOP的功能,且实现方式更为简捷,使用更加方便,而且 ...
- Java空白final
Java 1.1允许我们创建"空白final",它们属于一些特殊的字段.尽管被申明为final,但却未得到一个初始值. 无论在哪种情况下,空白final都必须在实际使用前得到正确的 ...
- Linux学习笔记18--Linux系统服务基础
服务(Service):运行在操作系统后台的一个或多个程序,为用户或系统提供某项特定的服务. 服务通常是不中断运行的,随时接收请求,提供某项服务.例如:http网页服务由诸如nginx.apach ...