2016-05-08 69 views
0

我在SQL Server 2012中编写了下一个脚本,但它在约束上失败。SQL Server切换群集表

我有一张有20 000 000行的表格。 我创建相同的表与分区索引相同,但是当我切换 表时,SQL Server未能

这里是我的代码:

CREATE DATABASE test 
USE test 

create Partition Function 
[PF_Table_Log] ([DATETIME2](3)) As Range left For VALUES 
('2016-04-05 00:00:00.000','2016-04-06 00:00:00.000', 
'2016-04-07 00:00:00.000','2016-04-08 00:00:00.000') 



Create Partition Scheme PS_Table_Log_Datetime 
As Partition [PF_Table_Log] 
All To ([Primary]); 


create TABLE [Log](
[LogId] [BIGINT] IDENTITY(1,1) NOT NULL, 
[ServiceInstanceId] [UNIQUEIDENTIFIER] NULL, 
[ServiceId] [UNIQUEIDENTIFIER] NOT NULL, 
[Component] [NVARCHAR](100) NULL, 
[MachineName] [NVARCHAR](50) NULL, 
[Datetime] [DATETIME2](3) NOT NULL, 
[Severity] [INT] NOT NULL, 
[LogText] [NVARCHAR](max) NULL, 
[MessageId] [UNIQUEIDENTIFIER] NULL, 
[MessageRole] [INT] NULL 
) ON [PRIMARY] 

GO 

CREATE CLUSTERED INDEX [PK_Log] ON [Log] 
(

[LogId] ASC, 
[datetime] ASC 

)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, 
DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON,ALLOW_PAGE_LOCKS=ON)    
GO 


create TABLE [Log_new1](
[LogId] [BIGINT] IDENTITY(1,1) NOT NULL, 
[ServiceInstanceId] [UNIQUEIDENTIFIER] NULL, 
[ServiceId] [UNIQUEIDENTIFIER] NOT NULL, 
[Component] [NVARCHAR](100) NULL, 
[MachineName] [NVARCHAR](50) NULL, 
[Datetime] [DATETIME2](3) NOT NULL, 
[Severity] [INT] NOT NULL, 
[LogText] [NVARCHAR](max) NULL, 
[MessageId] [UNIQUEIDENTIFIER] NULL, 
[MessageRole] [INT] NULL 
) ON PS_Table_Log_Datetime (datetime) 
GO 


CREATE CLUSTERED INDEX [PK_Log] ON [Log_new1] 
(
[LogId] ASC,[Datetime] asc 
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, 
) ON PS_Table_Log_Datetime ([Datetime]) 




ALTER TABLE [Log] SWITCH TO [Log_new1] PARTITION 5 

回答

0

“我有相同的索引创建相同的表有分区,但是当我切换表时,SQL Server失败“

这条语句与脚本不一致。表Log未分区,但是Log_new1是。您需要使用相同的分区方案对Log进行分区,或者对匹配目标分区边界的Log表列创建检查约束。最后一个分区所需的检查约束定义为:

ALTER TABLE Log ADD CONSTRAINT CK_Log_Datetime CHECK (Datetime > '2016-04-08 00:00:00.000');