修復錯誤 1093 (HY000):刪除 MySQL 列中的最小值時,無法在 FROM 子句中指定用於在更新中的目標表?
我們首先建立一個表 -
mysql> create table DemoTable1597 -> ( -> Marks int -> ); Query OK, 0 rows affected (0.69 sec)
使用 insert 命令在表中插入一些記錄 -
mysql> insert into DemoTable1597 values(45); Query OK, 1 row affected (0.21 sec) mysql> insert into DemoTable1597 values(59); Query OK, 1 row affected (0.24 sec) mysql> insert into DemoTable1597 values(43); Query OK, 1 row affected (0.11 sec) mysql> insert into DemoTable1597 values(85); Query OK, 1 row affected (0.17 sec) mysql> insert into DemoTable1597 values(89); Query OK, 1 row affected (0.12 sec)
使用 select 語句顯示錶中的所有記錄 -
mysql> select * from DemoTable1597;
這將產生以下輸出 -
+-------+ | Marks | +-------+ | 45 | | 59 | | 43 | | 85 | | 89 | +-------+ 5 rows in set (0.00 sec)
以下是消除錯誤 1093 (HY000) 的查詢。我們在此處刪除了最小值 -
mysql> delete from DemoTable1597 -> where Marks=( -> select lowestMarks from ( select min(Marks) as lowestMarks from DemoTable1597 ) as deleteRecord -> ) limit 1; Query OK, 1 row affected (0.11 sec)
讓我們再次檢查表記錄 -
mysql> select * from DemoTable1597;
這將產生以下輸出 -
+-------+ | Marks | +-------+ | 45 | | 59 | | 85 | | 89 | +-------+ 4 rows in set (0.00 sec)
廣告