SQL普通表转分区表的方法
SQL普通表转分区表的方法
发布时间:2016-12-29 来源:查字典编辑
摘要:复制代码代码如下:CREATETABLESale([Id][int]identity(1,1)NOTNULL,--自动增长[Name][va...

复制代码 代码如下:

CREATE TABLE Sale(

[Id] [int] identity(1,1) NOT NULL, --自动增长

[Name] [varchar](16) NOT NULL,

[SaleTime] [datetime] NOT NULL,

constraint [PK_Sale] primary key clustered --创建主键

(

[Id] ASC

)

)

--插入一些记录

insert Sale ([Name],[SaleTime]) values ('张三','2009-1-1')

insert Sale ([Name],[SaleTime]) values ('李四','2009-2-1')

insert Sale ([Name],[SaleTime]) values ('王五','2009-3-1')

insert Sale ([Name],[SaleTime]) values ('钱六','2010-4-1')

insert Sale ([Name],[SaleTime]) values ('赵七','2010-5-1')

insert Sale ([Name],[SaleTime]) values ('张三','2011-6-1')

insert Sale ([Name],[SaleTime]) values ('李四','2011-7-1')

insert Sale ([Name],[SaleTime]) values ('王五','2011-8-1')

insert Sale ([Name],[SaleTime]) values ('钱六','2012-9-1')

insert Sale ([Name],[SaleTime]) values ('赵七','2012-10-1')

insert Sale ([Name],[SaleTime]) values ('张三','2012-11-1')

insert Sale ([Name],[SaleTime]) values ('李四','2013-12-1')

insert Sale ([Name],[SaleTime]) values ('王五','2014-12-1')

alter table Sale drop constraint PK_Sale

--创建主键,但不设为聚集索引

alter TABLE Sale add constraint PK_Sale primary key nonclustered

(

[ID] ASC

) ON [PRIMARY]

--创建分区函数

GO

create partition function [pf_Sale](SaleTime) as range left for values(N'2010-5-1T00:00:00.000', N'2012-9-1T00:00:00.000'

GO

--创建分区结构

GO

create partition scheme [pt_Sale] as partition [pf_Sale] TO ([Sale1], [Sale3], [Sale2])

GO

--创建一个使用[pt_Sale]架构

GO

create table [dbo].[AvCache](

[Id] [int] identity(1,1) NOT NULL, --自动增长

[Name] [varchar](16) NOT NULL,

[SaleTime] [datetime] NOT NULL,

)on [pt_Sale](SaleTime) --注意这里使用[pt_Sale]架构,根据SaleTime 分区

-- 查看使用情况

SELECT *, $PARTITION.[pt_Sale](SaleTime)

FROM dbo.[AvCache]

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新mssql数据库学习
热门mssql数据库学习
编程开发子分类