首頁  >  文章  >  資料庫  >  如何在具有唯一約束的 MySQL 中交換行值?

如何在具有唯一約束的 MySQL 中交換行值?

Linda Hamilton
Linda Hamilton原創
2024-10-26 04:23:31250瀏覽

 How to Swap Row Values in MySQL with a Unique Constraint?

MySQL 交換具有唯一約束的行值

在MySQL 中,交換優先權列上具有唯一約束的兩行的優先權值可以是挑戰。

問題:

使用此語句交換值時:

UPDATE tasks 
SET priority = 
CASE
    WHEN priority=2 THEN 3 
    WHEN priority=3 THEN 2 
END 

WHERE priority IN (2,3);

由於重複條目違規而發生錯誤

解決方案:

不幸的是,在MySQL 中,不使用多個查詢或虛假值來交換值是不可能的。這是因為 MySQL 在每行更新後強制進行約束檢查,與其他一些 DBMS 不同。

替代方法:

要在不違反約束的情況下交換值,您可以使用在交易中執行以下步驟:

  1. 用虛假值更新行: 將一行的優先權設定為不存在的負值(-2),另一行設定為另一個負值(-3)。
  2. 使用負值交換值:對虛假值(-priority)求反以交換優先權。
  3. 提交交易:永久套用變更。

交易聲明:

START TRANSACTION ;
    UPDATE tasks 
    SET priority = 
      CASE
        WHEN priority = 2 THEN -3 
        WHEN priority = 3 THEN -2 
      END 
    WHERE priority IN (2,3) ;

    UPDATE tasks 
    SET priority = - priority
    WHERE priority IN (-2,-3) ;
COMMIT ;

注意:

這種方法要求唯一值的有符號整數。如果允許負值,則可能需要不同的解決方案。

以上是如何在具有唯一約束的 MySQL 中交換行值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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