sql-update - 从 Azure SQL DW 中更新?

标签 sql-update azure-sqldw

我在尝试执行 UPDATE FROM 查询时在 Azure SQL DW 中收到错误。错误是“UPDATE 和 DELETE 语句中的 FROM 子句不能包含子查询源或连接”

这只是特定于 SQL DW 吗?否则,我认为此查询没有任何问题。如果是 SQL DW 的限制,有什么替代方案?

-- Permanent fact table with 5 billion rows
CREATE TABLE FactTable (Id1 INT, Id2 INT, EmailAddress NVARCHAR(100), Value1 INT)
WITH (DISTRIBUTION = HASH(EmailAddress));

-- Staging fact table with 10 million rows    
CREATE TABLE StageTable (Id1 INT, Id2 INT, EmailAddress NVARCHAR(100), Value1 INT)
WITH (DISTRIBUTION = HASH(EmailAddress), HEAP);

-- Add a secondary index that should help with joining to StageTable
CREATE NONCLUSTERED INDEX ix ON FactTable (Id1, Id2);

UPDATE fact
SET
   Value1 = CASE WHEN stage.Value1 > fact.Value1 THEN stage.Value1 ELSE fact.Value1 END
FROM FactTable AS fact
INNER JOIN StageTable AS stage ON fact.Id1 = stage.Id1 AND fact.Id2 = stage.Id2

最佳答案

根据 the documentation Azure SQL 数据仓库确实支持 UPDATE但不支持 FROM 中的 ANSI 连接条款。您可以使用 CTAS 来解决。简单的两表更新:

UPDATE dbo.FactTable
SET
   Value1 = CASE WHEN stage.Value1 > dbo.FactTable.Value1 THEN stage.Value1 ELSE dbo.FactTable.Value1 END
FROM dbo.StageTable AS stage
WHERE dbo.FactTable.Id1 = stage.Id1 
  AND dbo.FactTable.Id2 = stage.Id2;

更复杂的 CTAS 示例,从 main UPDATE documentation page 批发复制:
-- Create an interim table
CREATE TABLE CTAS_acs
WITH (DISTRIBUTION = ROUND_ROBIN)
AS
SELECT  ISNULL(CAST([EnglishProductCategoryName] AS NVARCHAR(50)),0)    AS [EnglishProductCategoryName]
,       ISNULL(CAST([CalendarYear] AS SMALLINT),0)                      AS [CalendarYear]
,       ISNULL(CAST(SUM([SalesAmount]) AS MONEY),0)                     AS [TotalSalesAmount]
FROM    [dbo].[FactInternetSales]       AS s
JOIN    [dbo].[DimDate]                 AS d    ON s.[OrderDateKey]             = d.[DateKey]
JOIN    [dbo].[DimProduct]              AS p    ON s.[ProductKey]               = p.[ProductKey]
JOIN    [dbo].[DimProductSubCategory]   AS u    ON p.[ProductSubcategoryKey]    = u.[ProductSubcategoryKey]
JOIN    [dbo].[DimProductCategory]      AS c    ON u.[ProductCategoryKey]       = c.[ProductCategoryKey]
WHERE   [CalendarYear] = 2004
GROUP BY
        [EnglishProductCategoryName]
,       [CalendarYear]
;

-- Use an implicit join to perform the update
UPDATE  AnnualCategorySales
SET     AnnualCategorySales.TotalSalesAmount = CTAS_ACS.TotalSalesAmount
FROM    CTAS_acs
WHERE   CTAS_acs.[EnglishProductCategoryName] = AnnualCategorySales.[EnglishProductCategoryName]
AND     CTAS_acs.[CalendarYear]               = AnnualCategorySales.[CalendarYear]
;

--Drop the interim table
DROP TABLE CTAS_acs
;

关于sql-update - 从 Azure SQL DW 中更新?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49515170/

相关文章:

sql-server - Azure SQL 数据仓库表中的分区数据

azure-sqldw - Azure SQL DW如何在没有统计信息的情况下知道行数?

mysql - 如何在树结构中设置嵌套路径值?

mysql - MySQL 中的日期时间转换

r - R sqlite:使用两个表进行更新会给出语法错误“near”。”:

sql-server - 必须声明标量变量 "@@procid"

php - 我的 AJAX 代码不更新数据库

mysql - MySQL 中的跨表更新

azure-sqldw - 为 Polybase 创建存储过程 - 无法传入参数