簡體   English   中英

分區圖表 - 分區切換失敗

[英]Partitioned Graph table - Partition Switch failed

我正在嘗試分區到現有的 SQL Server 圖形表(節點)。 該表非常大,刪除等需要很長時間,因此希望使用分區來提高性能。

但是,當我添加分區並嘗試切換數據時。 它失敗並出現以下錯誤:

消息 7733,級別 16,狀態 4,第 1 行“ALTER TABLE SWITCH”語句失敗。 表 tempdatabase.dbo.graphtable 已分區,而索引 'GRAPH_UNIQUE_INDEX_xxxxxxxxx' 未分區。

由於索引 GRAPH_UNIQUE_INDEX_xxxxxxxxx 是自動創建的,所以不能添加分區鍵吧。

CREATE PARTITION FUNCTION f_partfunction (INT) AS RANGE LEFT 
FOR VALUES (1,100,200,300)
GO

-- Create the partition scheme
CREATE PARTITION SCHEME s_partscheme
AS PARTITION f_partfunction
ALL TO ([PRIMARY]);
GO


CREATE TABLE [dbo].[graphtable](
    PartitionKey INT,
    ID INT,
    EName varchar(100))
 AS NODE  ON s_partscheme (PartitionKey)
go

CREATE TABLE [dbo].[graphtable_test](
    PartitionKey INT,
    ID INT,
    EName varchar(100))
 go

 --Failing Code
 ALTER TABLE [dbo].[graphtable] SWITCH PARTITION 3 TO [dbo].[graphtable_test]

您必須刪除當前索引,然后使用指向您擁有的分區架構的索引重新創建。

    CREATE INDEX GRAPH_UNIQUE_INDEX_xxxxxxxxx' ON graphtable
    (
    "Your column"
    )
    INCLUDE (  [Primary Key column]) WITH (DATA_COMPRESSION = PAGE) ON
    [s_partscheme] (PartitionKey)
    GO

在你的情況下,我猜測它的 PartitionKey,用作分區列。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM