SQL Server执行计划审核请求

时间:2017-02-02 11:03:00

标签: sql sql-server execution

无法理解为什么我的查询花了这么长时间,请寻求优化的建议。

update Laserbeak_Main.dbo.ACCOUNT_MPN set
    DateUpgrade = ord.ConnectedDate
                    FROM [ORDER] ord
                    WHERE ord.AccountNumber = Laserbeak_Main.dbo.ACCOUNT_MPN.AccountNumber
                    AND ord.ordertypeID = '2'
                    AND ord.ConnectedDate IS NOT NULL
                    AND DateUpgrade <> ord.ConnectedDate

enter image description here

Execution plan as requested on brentozar.com

更新:根据建议,新查询看起来像这样&amp;似乎工作得更快。但是,如果您运行查询,它会按预期设置行,然后再次运行它会更新完全相同的行数。转换为选择确认每次都更新相同的行。 &lt;&gt;条款应该停止,但它不会。我认为它与排序有关,但无法确认是否可能在同一数据库中的表级别具有不同的排序规则。

;WITH cteOrderInfo AS (
SELECT DISTINCT ord.AccountNumber, ord.ConnectedDate
FROM [ORDER] ord
WHERE ord.ordertypeID = '2'
AND ord.ConnectedDate IS NOT NULL
)
UPDATE Laserbeak_Main.dbo.ACCOUNT_MPN
SET Laserbeak_Main.dbo.ACCOUNT_MPN.DateUpgrade = cteOrderInfo.ConnectedDate
FROM cteOrderInfo
INNER JOIN Laserbeak_Main.dbo.ACCOUNT_MPN acc
ON cteOrderInfo.AccountNumber = acc.AccountNumber
WHERE cteOrderInfo.ConnectedDate <> acc.DateUpgrade

要确认的SELECT:

;WITH cteOrderInfo AS (
SELECT DISTINCT ord.AccountNumber, ord.ConnectedDate
FROM [ORDER] ord
WHERE ord.ordertypeID = '2'
AND ord.ConnectedDate IS NOT NULL
)
SELECT cteOrderInfo.ConnectedDate, acc.DateUpgrade
FROM cteOrderInfo
INNER JOIN Laserbeak_Main.dbo.ACCOUNT_MPN acc
ON cteOrderInfo.AccountNumber = acc.AccountNumber
WHERE cteOrderInfo.ConnectedDate <> acc.DateUpgrade

SELECT Results Sample:

enter image description here

1 个答案:

答案 0 :(得分:0)

正如Serge建议的那样,我们没有独特的行。

我们到达的解决方案:

;WITH cteSourceStuff AS (
      SELECT AccountNumber, MpnUpgrade, MAX(DateConnected) maxConnDate
      FROM ORDER_DETAIL, [ORDER]
      WHERE ORDER_DETAIL.OrderID = [ORDER].OrderID
      AND LEN(MpnUpgrade) > 10
      AND OrderTypeID = 2
      GROUP BY AccountNumber, MpnUpgrade
      )
      UPDATE Laserbeak_Main.dbo.ACCOUNT_MPN set
              DateUpgrade = cteSourceStuff.maxConnDate
              FROM cteSourceStuff
              WHERE cteSourceStuff.MpnUpgrade = ACCOUNT_MPN.Mpn
              AND cteSourceStuff.AccountNumber = ACCOUNT_MPN.AccountNumber
              AND DateUpgrade <> cteSourceStuff.maxConnDate

这很有效,因为最初删除了重复项,然后我们只更新了实际定位的行。我们之前遇到问题的原因是SQL正在更新它找到的第一行,然后当我们重新运行或运行select时,它是在键上匹配的返回行,但之前没有更新过。