DROP TABLE如果命名表不存在,并且未進行任何更改(無論存儲引擎如何),則會失敗并顯示錯誤。如下所示:
mysql> CREATE TABLE t1 (c1 INT);
mysql> DROP TABLE t1, t2;
ERROR 1051 (42S02): Unknown table 'test.t2'
mysql> SHOW TABLES;
+----------------+
| Tables_in_test |
+----------------+
| t1 |
+----------------+
在引入原子DDL之前, DROP TABLE雖然會報錯誤表不存在,但是存在的表會被執行成功,如下:
mysql> CREATE TABLE t1 (c1 INT);
mysql> DROP TABLE t1, t2;
ERROR 1051 (42S02): Unknown table 'test.t2'
mysql> SHOW TABLES;
Empty set (0.00 sec)
注意:
由于行為的這種變化,DROP TABLE會在 MySQL 5.7主服務器上的部分完成 語句在MySQL 8.0從服務器上復制時失敗。要避免此故障情形,請在DROP TABLE語句中使用IF EXISTS語法以防止對不存在的表發生錯誤
3.2、DROP DATABASE:
如果所有表都使用原子DDL支持的存儲引擎,則為atomic。該語句要么成功刪除所有對象,要么回滾。但是,從文件系統中刪除數據庫目錄是最后一次,并且不是原子事務的一部分。如果由于文件系統錯誤或服務器暫停而導致數據庫目錄的刪除失敗, DROP DATABASE則不會回滾事務。
3.3、對于不使用原子DDL支持的存儲引擎的表,表刪除發生在原子 DROP TABLE或 DROP DATABASE事務之外。這樣的表刪除被單獨寫入二進制日志,這在中斷DROP TABLE或 DROP DATABASE操作的情況下將存儲引擎,數據字典和二進制日志之間的差異限制為最多一個表 。對于刪除多個表的操作,不使用原子DDL支持的存儲引擎的表將在執行之前刪除。
3.4、CREATE TABLE, ALTER TABLE, RENAME TABLE, TRUNCATE TABLE, CREATE TABLESPACE,和 DROP TABLESPACE對使用原子DDL支持的存儲引擎表執行的操作要么完全提交或如果服務器的操作時停止回滾。在早期的MySQL版本中,這些操作的中斷可能會導致存儲引擎,數據字典和二進制日志之間的差異,或留下孤立文件。RENAME TABLE如果所有命名表都使用原子DDL支持的存儲引擎,則操作只是原子操作。
3.5、DROP VIEW:
如果命名視圖不存在且未進行任何更改,則會失敗。在此示例中演示了行為更改,其中 DROP VIEW語句失敗,因為命名視圖不存在,如下:
mysql> CREATE VIEW test.viewA AS SELECT * FROM t;
mysql> DROP VIEW test.viewA, test.viewB;
ERROR 1051 (42S02): Unknown table 'test.viewB'
mysql> SHOW FULL TABLES IN test WHERE TABLE_TYPE LIKE 'VIEW';
+----------------+------------+
| Tables_in_test | Table_type |
+----------------+------------+
| viewA | VIEW |
+----------------+------------+
在引入原子DDL之前, 使用DROP VIEW刪除視圖會報錯,但是存在的視圖會被成功刪除:
mysql> CREATE VIEW test.viewA AS SELECT * FROM t;
mysql> DROP VIEW test.viewA, test.viewB;
ERROR 1051 (42S02): Unknown table 'test.viewB'
mysql> SHOW FULL TABLES IN test WHERE TABLE_TYPE LIKE 'VIEW';