首頁 > 資料庫 > mysql教程 > 為什麼無法使用在 FROM 子句中引用同一表的子查詢來更新 MySQL 表?

為什麼無法使用在 FROM 子句中引用同一表的子查詢來更新 MySQL 表?

Patricia Arquette
發布: 2025-01-22 19:47:13
原創
490 人瀏覽過

Why Can't I Update a MySQL Table Using a Subquery Referencing the Same Table in the FROM Clause?

MySQL UPDATE語句中FROM子句引用同一表的問題

場景:

考慮名為pers的MySQL表:

CREATE TABLE IF NOT EXISTS `pers` (
  `persID` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(35) NOT NULL,
  `gehalt` int(11) NOT NULL,
  `chefID` int(11) DEFAULT NULL,
  PRIMARY KEY (`persID`)
) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=4 ;

INSERT INTO `pers` (`persID`, `name`, `gehalt`, `chefID`) VALUES
(1, 'blb', 1000, 3),
(2, 'as', 1000, 3),
(3, 'chef', 1040, NULL);
登入後複製

問題:

嘗試執行以下UPDATE語句會導致錯誤1093:

UPDATE pers P 
SET P.gehalt = P.gehalt * 1.05 
WHERE (P.chefID IS NOT NULL 
OR gehalt < 1000);
登入後複製

原因:

該錯誤發生是因為MySQL不允許在UPDATE/INSERT/DELETE查詢中從子查詢內部引用目標表。

解:

為了解決這個問題,需要重寫子查詢,將目標表中必要的欄位明確複製到臨時表中。這可以透過用(SELECT * FROM target_table)取代目標表的實例來實現。 然而,本例中並不需要子查詢,直接修改即可。

正確的查詢:

UPDATE pers P 
SET P.gehalt = P.gehalt * 1.05 
WHERE (P.chefID IS NOT NULL 
OR P.gehalt < 1000);
登入後複製

這個修改後的查詢直接在WHERE子句中使用P.gehalt,避免了MySQL的限制,從而正確地更新pers表。 無需建立臨時表。

以上是為什麼無法使用在 FROM 子句中引用同一表的子查詢來更新 MySQL 表?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板