首頁 >資料庫 >mysql教程 >如何解決因重複記錄檢索而導致的訂單處理中的 SQL Server 競態條件?

如何解決因重複記錄檢索而導致的訂單處理中的 SQL Server 競態條件?

Patricia Arquette
Patricia Arquette原創
2025-01-18 01:22:10581瀏覽

How Can I Resolve a SQL Server Race Condition in Order Processing Due to Duplicate Record Retrieval?

解決訂單處理中的 SQL Server 競爭條件

您的訂單處理系統正在經歷競爭條件,因為多個處理器正在檢索相同的記錄。 解決此問題的方法如下:

理解問題:

問題源自於預存程序使用 ROWLOCK 提示並結合單獨鎖定的視圖中的選擇。這允許多個處理器鎖定同一筆記錄,從而導致資料損壞。

解決方案使用提示:

要解決競爭條件,請使用 READPASTUPDLOCK 提示:

<code class="language-sql">BEGIN TRAN
    UPDATE TOP (20)
    OrderTable foo
SET
    ProcessorID = @PROCID
FROM
    foo WITH (ROWLOCK, READPAST, UPDLOCK)
WHERE
    ProcessorID = 0
COMMIT TRAN

SELECT
    OrderID, ProcessorID, etc...
FROM
    OrderTable
WHERE
    ProcessorID = @PROCID</code>

READPAST 避免在選擇過程中鎖定行,確保連續查詢執行。 UPDLOCK 確保更新期間正確鎖定,防止並發修改。

更有效的解決方案:

更簡化的方法使用 OUTPUT 子句來組合 SELECTUPDATE 操作:

<code class="language-sql">BEGIN TRAN
    UPDATE TOP (20) foo
    OUTPUT
        OrderID, ProcessorID, etc...
    SET
        ProcessorID = @PROCID
FROM
    foo WITH (ROWLOCK, UPDLOCK, READPAST)
WHERE
    ProcessorID = 0
COMMIT TRAN</code>

這消除了對單獨的 SELECT 語句的需要,提高了效率和程式碼清晰度。

以上是如何解決因重複記錄檢索而導致的訂單處理中的 SQL Server 競態條件?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn