千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 為什么數(shù)據(jù)庫 DDL 不支持事務回滾?

為什么數(shù)據(jù)庫 DDL 不支持事務回滾?

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-10-14 00:49:32 1697215772

一、為什么數(shù)據(jù)庫DDL不支持事務回滾

一般數(shù)據(jù)庫的實現(xiàn),以Oracle為例,在執(zhí)行DDL后會隱式提交。所以你看上去好像DDL不會回滾。其實你可以做個實驗,在同一個事務里執(zhí)行幾條DML,再執(zhí)行DDL,再回滾。你會發(fā)現(xiàn)DDL之前執(zhí)行的DML也不會回滾,因為數(shù)據(jù)庫已經幫你提交了。

當然你會問為什么這么實現(xiàn),這是因為內存空間有限,DDL是修改數(shù)據(jù)字典,而且通常不會有長時間的DDL執(zhí)行。數(shù)據(jù)庫自動提交有助于控制數(shù)據(jù)字典的內存占用,把更多的空間留給DML。

Oracle為了實現(xiàn)DDL可以回滾的功能,且實現(xiàn)多版本讀一致性,那么就必須在DDL發(fā)生后,將修改的表鎖定,避免其他會話的訪問造成不一致這會導致Oracle中出現(xiàn)鎖升級的情況,并且嚴重的影響Oracle的并發(fā)性,而且會大大增加死鎖產生的幾率要知道,Oracle的鎖機制和多版本讀一致性使得Oracle的并發(fā)性在所有數(shù)據(jù)庫產品中首屈一指。

顯然為了實現(xiàn)DDL的回滾而損失最值得稱道的并發(fā)性,Oracle認為得不償失。 ?

延伸閱讀:

二、SQL TRUNCATE TABLE清空表語句

SQL TRUNCATE TABLE 語句用來刪除表中的所有記錄,也即清空表,它類似于不帶 WHERE 子句的 DELETE FROM 語句。

TRUNCATE TABLE 和?DROP TABLE

DROP TABLE 用來刪除表,包括刪除該表的數(shù)據(jù)、結構、索引、觸發(fā)器、約束等所有信息。一旦使用?DROP TABLE 刪除了表,則該表的所有信息都將丟失,該表再也無法使用了。如果您希望存儲一些數(shù)據(jù),就只能重新創(chuàng)建該表。
TRUNCATE TABLE 僅僅刪除表的所有記錄,表的結構、索引、觸發(fā)器、約束等將被保留,后續(xù)仍然可以使用該表。

TRUNCATE TABLE 和 DELETE FROM

不帶 WHERE 子句的?DELETE FROM 語句同樣可以達到清空表的效果,但是?TRUNCATE TABLE 使用的系統(tǒng)資源和日志資源更少,因此比?DELETE FROM 更加快速。
DELETE FROM 語句每刪除一行,都會在事務日志中為所刪除的行記錄一項。TRUNCATE TABLE 通過釋放表中數(shù)據(jù)所用的數(shù)據(jù)頁來刪除數(shù)據(jù),只會在事務日志中記錄頁的釋放。
此外,TRUNCATE TABLE 還能重置具有自動遞增(AUTO_INCREMENT)屬性的字段,而 DELETE FROM 卻不具備該功能。

總結

當您不再需要該表時,使用 DROP TABLE;當您仍要保留該表,只是想刪除所有記錄時,使用 TRUNCATE TABLE;當你要刪除部分記錄時,使用帶有 WHERE 子句的 DELETE FROM。
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業(yè)內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
oracle怎么樣實現(xiàn)數(shù)據(jù)庫跨機房同步?

一、oracle怎么樣實現(xiàn)數(shù)據(jù)庫跨機房同步除了使用第三方工具,Oracle提供了extended cluster可以實現(xiàn)類似的功能,使用Oracle RAC + ASM。簡單說下...詳情>>

2023-10-14 01:57:43
web網站性能測試的常用指標有哪些?

一、頁面加載時間頁面加載時間是衡量網站性能的重要指標之一,它指的是從用戶請求一個頁面到頁面完全加載完成所需的時間。頁面加載時間的長短直...詳情>>

2023-10-14 01:50:34
MySQL索引為什么能讓查詢效率提高?

一、MySQL索引為什么能讓查詢效率提高DB在執(zhí)行一條Sql語句的時候,默認的方式是根據(jù)搜索條件進行全表掃描。如果我們對某一字段增加索引,查詢時...詳情>>

2023-10-14 01:38:15
什么是面向云原生系統(tǒng)的智能運維?

一、云原生系統(tǒng)概述云原生系統(tǒng)是指在云計算環(huán)境下構建和運行的應用程序系統(tǒng),具備高可用、彈性擴展、靈活部署和自動化管理等特點。它采用容器化...詳情>>

2023-10-14 01:25:33
怎么提升excel數(shù)據(jù)表訪問運算速度?

一、怎么提升excel數(shù)據(jù)表訪問運算速度目前版本Excel最大列數(shù)為16384,沒有10w加。運算速度和Excel中是否有公式、公式的復雜度、對象的對少、格...詳情>>

2023-10-14 01:22:48