truncate delete和drop的區別

2021-08-15 20:29:09 字數 371 閱讀 7845

truncate table 在功能上與不帶 where 子句的 delete 語句相同:二者均刪除表中的全部行。但 truncate table 比 delete 速度快,且使用的系統和事務日誌資源少。
delete 語句每次刪除一行,並在事務日誌中為所刪除的每行記錄一項。

truncate table 通過釋放儲存表資料所用的資料頁來刪除資料,並且只在事務日誌中記錄頁的釋放。

truncate,delete,drop放在一起比較:

truncate table:刪除內容、不刪除定義、釋放空間。

delete table:刪除內容、不刪除定義,不釋放空間。

drop table:刪除內容和定義,釋放空間。

truncate delete和drop的異同

truncate table命令將快速刪除資料表中的所有記錄,但保留資料表結構。這種快速刪除與delete from 資料表的刪除全部資料表記錄不一樣,delete命令刪除的資料將儲存在系統回滾段中,需要的時候,資料可以回滾恢復,而truncate命令刪除的資料是不可以恢復的 可以做乙個測試 建乙個...

truncate delete和drop的異同點

相同點 truncate和不帶where子句的delete,以及drop都會刪除表內的資料 不同點 1.truncate和delete只刪除資料不刪除表的結構 定義 drop語句將刪除表的結構被依賴的約束 constrain 觸發器 trigger 索引 index 依賴於該錶的儲存過程 函式將保留...

truncate delete 清空內容

delete from表名 truncate table表名 不帶where 引數的delete 語句可以刪除 mysql 表中所有內容,使用 truncate table 也可以清空 mysql 表中所有內容。效率上truncate 比delete 快,但truncate 刪除後不記錄 mysql...