0

当我尝试在一个 SQL 事务中捕获增量负载时。更新不起作用。基本上,它会无限期地执行 90k 行。

输入 SQL 事务

BEGIN;
INSERT INTO IncrementalLoad_Dest.dbo.tblDest
(ColID, ColA, ColB, ColC)
SELECT s.ColID, s.ColA, s.ColB, s.ColC 
FROM IncrementalLoad_Source.dbo.tblSource s
LEFT JOIN IncrementalLoad_Dest.dbo.tblDest d ON d.ColID = s.ColID
WHERE d.ColID IS NULL ;
UPDATE d
SET
d.ColA = s.ColA
,d.ColB = s.ColB
,d.ColC = s.ColC
FROM IncrementalLoad_Dest.dbo.tblDest d
INNER JOIN IncrementalLoad_Source.dbo.tblSource s ON s.ColID = d.ColID
WHERE (
(d.ColA != s.ColA)
OR (d.ColB != s.ColB) 
OR (d.ColC != s.ColC)
);
END;

更新语句未从psql实用程序执行。为什么它继续执行甚至不抛出错误。

此外,尝试检查目标文件上的活动锁定。不存在锁。

请考虑每列周围的双引号列和用 greenplum SQL 语法编写的 SQL 事务。

对此的任何帮助将不胜感激。

4

1 回答 1

1

尝试这个:

UPDATE IncrementalLoad_Dest_dbo.tblDest d
SET d.ColA = s.ColA,
    d.ColB = s.ColB,
    d.ColC = s.ColC
FROM IncrementalLoad_Source_dbo.tblSource s 
WHERE s.ColID = d.ColID
and ((d.ColA != s.ColA) OR (d.ColB != s.ColB) OR (d.ColC != s.ColC));

您基本上必须更改您的 SQL Server 语法以更符合 ANSI,以便它在 Greenplum 中工作。

此外,您可能希望避免使用 UPDATE 语句。在执行 UPDATE 之前,您肯定需要 VACUUM。您可能希望在创建表时使表追加优化 (appendonly=true)。

于 2017-02-26T20:14:58.467 回答