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 不同。
替代方法:
要在不違反約束的情況下交換值,您可以使用在交易中執行以下步驟:
交易聲明:
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中文網其他相關文章!