分区图表 - 分区切换失败

Posted

技术标签:

【中文标题】分区图表 - 分区切换失败【英文标题】:Partitioned Graph table - Partition Switch failed 【发布时间】:2019-03-13 16:44:20 【问题描述】:

我正在尝试分区到现有的 SQL Server Graph 表(节点)。表很大,删除等操作耗时较长,希望通过分区来提高性能。

但是,当我添加分区并尝试切换数据时。它失败并出现以下错误:

消息 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]

【问题讨论】:

“桌子很大” - 多大? 我认为您不能创建对齐的分区图表(SWITCH 需要),因为分区列 (PartitionKey) 不是 $node 上唯一索引的一部分。分区提高了可管理性,但不一定提高性能。索引(我在您的问题中没有看到)和查询调优是提高性能的第一步。 【参考方案1】:

您必须删除当前索引,然后使用指向您拥有的分区架构的索引重新创建。

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

在你的情况下,我猜测它的 PartitionKey,用作 Partition 列。

【讨论】:

graph_unique_index_xxxxxxx 是使用节点表自动创建的。它不能被丢弃或改变。 Msg 13925,Level 16,State 1,Line 1 无法删除或禁用索引或约束“GRAPH_UNIQUE_INDEX_xxxxxxxxxxx”,因为无法删除或禁用“$node_id”上的最后一个唯一索引或约束。 你不需要删除主键,即聚集索引

以上是关于分区图表 - 分区切换失败的主要内容,如果未能解决你的问题,请参考以下文章

合并分区失败

重新分区 pyspark 数据帧失败以及如何避免初始分区大小

pg添加分区失败

win10下使用分区工具分区失败原因分析

hive 脚本由于堆空间问题而失败,无法处理太多分区

合并分区失败后怎样恢复数据