一、為什么數(shù)據(jù)庫DDL不支持事務(wù)回滾
一般數(shù)據(jù)庫的實現(xiàn),以O(shè)racle為例,在執(zhí)行DDL后會隱式提交。所以你看上去好像DDL不會回滾。其實你可以做個實驗,在同一個事務(wù)里執(zhí)行幾條DML,再執(zhí)行DDL,再回滾。你會發(fā)現(xiàn)DDL之前執(zhí)行的DML也不會回滾,因為數(shù)據(jù)庫已經(jīng)幫你提交了。
當(dāng)然你會問為什么這么實現(xiàn),這是因為內(nèi)存空間有限,DDL是修改數(shù)據(jù)字典,而且通常不會有長時間的DDL執(zhí)行。數(shù)據(jù)庫自動提交有助于控制數(shù)據(jù)字典的內(nèi)存占用,把更多的空間留給DML。
Oracle為了實現(xiàn)DDL可以回滾的功能,且實現(xiàn)多版本讀一致性,那么就必須在DDL發(fā)生后,將修改的表鎖定,避免其他會話的訪問造成不一致這會導(dǎo)致Oracle中出現(xiàn)鎖升級的情況,并且嚴(yán)重的影響Oracle的并發(fā)性,而且會大大增加死鎖產(chǎn)生的幾率要知道,Oracle的鎖機制和多版本讀一致性使得Oracle的并發(fā)性在所有數(shù)據(jù)庫產(chǎn)品中首屈一指。
顯然為了實現(xiàn)DDL的回滾而損失最值得稱道的并發(fā)性,Oracle認(rèn)為得不償失。 ?
延伸閱讀:
二、SQL TRUNCATE TABLE清空表語句
SQL TRUNCATE TABLE 語句用來刪除表中的所有記錄,也即清空表,它類似于不帶 WHERE 子句的 DELETE FROM 語句。
TRUNCATE TABLE 和?DROP TABLE
DROP TABLE 用來刪除表,包括刪除該表的數(shù)據(jù)、結(jié)構(gòu)、索引、觸發(fā)器、約束等所有信息。一旦使用?DROP TABLE 刪除了表,則該表的所有信息都將丟失,該表再也無法使用了。如果您希望存儲一些數(shù)據(jù),就只能重新創(chuàng)建該表。
TRUNCATE TABLE 僅僅刪除表的所有記錄,表的結(jié)構(gòu)、索引、觸發(fā)器、約束等將被保留,后續(xù)仍然可以使用該表。
TRUNCATE TABLE 和 DELETE FROM
不帶 WHERE 子句的?DELETE FROM 語句同樣可以達(dá)到清空表的效果,但是?TRUNCATE TABLE 使用的系統(tǒng)資源和日志資源更少,因此比?DELETE FROM 更加快速。
DELETE FROM 語句每刪除一行,都會在事務(wù)日志中為所刪除的行記錄一項。TRUNCATE TABLE 通過釋放表中數(shù)據(jù)所用的數(shù)據(jù)頁來刪除數(shù)據(jù),只會在事務(wù)日志中記錄頁的釋放。
此外,TRUNCATE TABLE 還能重置具有自動遞增(AUTO_INCREMENT)屬性的字段,而 DELETE FROM 卻不具備該功能。
總結(jié)
當(dāng)您不再需要該表時,使用 DROP TABLE;當(dāng)您仍要保留該表,只是想刪除所有記錄時,使用 TRUNCATE TABLE;當(dāng)你要刪除部分記錄時,使用帶有 WHERE 子句的 DELETE FROM。