首頁 > 資料庫 > mysql教程 > 如何解決 MySQL 錯誤 1093:「您無法在 FROM 子句中指定用於更新的目標表 'table_name'」?

如何解決 MySQL 錯誤 1093:「您無法在 FROM 子句中指定用於更新的目標表 'table_name'」?

Patricia Arquette
發布: 2024-12-24 15:12:15
原創
629 人瀏覽過

How to Solve MySQL Error 1093:

MySQL 錯誤1093:理解並克服限制

在MySQL 中,嘗試修改也在FROM 子句中引用的表相同的查詢可能會導致錯誤:「您無法在FROM 子句中指定用於更新的目標表'table_name'。」此限制是由於MySQL無法直接執行此類操作。

要解決此問題,可以考慮以下幾種方法:

將表連接到自身

一種選擇是使用適當的選擇標準將表格與其自身連接起來,從MySQL 的角度建立表格的兩個不同實例。這允許在一個實例上執行破壞性操作,同時保持另一個實例不變。

在FROM 子句中巢狀子查詢

另一個解法是巢狀產生目標的子查詢更深層的FROM 子句中要刪除的行。這會根據子查詢建立一個隱式臨時表,MySQL 將其識別為與目標表不同的實體。但是,這種方法可能會影響效能。

停用最佳化器最佳化(MySQL 5.7.6 及更高版本)

從MySQL 5.7.6 開始,最佳化器可能會最佳化FROM 子句中的子查詢,導致錯誤持續存在。要解決此問題,請使用Optimizer_switch 變數停用最佳化:

SET optimizer_switch = 'derived_merge=off';
登入後複製

請注意,建議將其作為短期解決方案或用於小型一次性任務,因為它可能會對整體查詢效能產生負面影響。

結論

錯誤「您無法指定目標表'table_name' update in FROM 子句」源自MySQL 在修改也在FROM 子句中使用的表時的限制。透過採用上述方法,開發人員可以克服此限制並對其資料執行所需的操作。

以上是如何解決 MySQL 錯誤 1093:「您無法在 FROM 子句中指定用於更新的目標表 'table_name'」?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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