成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Truncate、Delete和Drop的六大區別!你知道幾個?

開發 前端
delete 是逐行執行的,并且在執行時會把操作日志記錄下來,以備日后回滾使用,所以 delete 的執行速度是比較慢的;而 truncate 的操作是先復制一個新的表結構,再把原先的表整體刪除,所以它的執行速度居中,而 drop 的執行速度最快。

在 MySQL  中,使用 truncate、delete 和 drop 都可以實現表刪除,但它們 3 個的使用場景和執行效果完全不同,接下來我們來盤點一下。

truncate、delete、drop區別概述

它們 3 個的區別如下表所示:

區別點

drop

truncate

delete

執行速度

較快

命令分類

DDL(數據定義語言)

DDL(數據定義語言)

DML(數據操作語言)

刪除對象

刪除整張表和表結構,以及表的索引、約束和觸發器。

只刪除表數據,表的結構、索引、約束等會被保留。

只刪除表的全部或部分數據,表結構、索引、約束等會被保留。

刪除條件(where)

不能用

不能用

可使用

回滾

不可回滾

不可回滾

可回滾

自增初始值

-

重置

不重置

接下來我們用案例來演示一下它們的區別。

準備工作

正式開始之前,我們先來創建一個用戶表和用戶測試數據,方便后續演示使用:

CREATE TABLE `userinfo` (
`id` int(11) NOT NULL AUTO_INCREMENT comment '編號',
`name` varchar(250) NOT NULL comment '姓名' unique,
`balance` decimal(10,2) NOT NULL DEFAULT '0.00' comment '賬戶余額',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
insert into userinfo values(1,'張三',1000),(2,'李四',500),(3,'王五',2000),(4,'李六',500);

創建的表結構和數據如下圖所示:

圖片

1.刪除對象不同

delete 和 truncate 只刪除表數據,不刪除表結構,其中 delete 刪除之后的結果如下:

圖片

我們先將表還原到初始狀態,再使用 truncate 執行刪除操作,執行結果如下圖所示:

圖片

把表還原到初始狀態,執行 drop 刪除語句,執行結果如下圖所示:

圖片

從上述結果可以看出,delete 和 truncate 只刪除表數據,而 drop 把表結構和表數據都刪除了。

2.刪除條件支持不同

truncate 和 drop 不支持添加 where 條件,而 delete 支持 where 條件,如下圖所示:

圖片

3.命令分類不同

truncate、delete 和 drop 所屬 SQL 分類不同,SQL 分為以下 3 類:

  • DDL【DataDefinitionLanguage】數據定義語言,用來維護存儲數據的結構代表指令: create、drop、alter、truncate。
  • DML【DataManipulationLanguage】數據操縱語言,用來對數據進行操作代表指令:insert,delete,update,DML 中又單獨分了一個 DQL,數據查詢語言,代表指令是 select。
  • DCL【DataControlLanguage】數據控制語言,主要負責權限管理和事務代表指令:grant,revoke,commit。

其中 delete 屬于 DML,而 truncate 和 drop 屬于 DDL。

PS:truncate 是先復制一個新的表結構,再把原有舊表結構和數據一起刪除,所以它屬于數據定義語言 DDL,而非數據操縱語言 DML。

4.回滾支持不同

delete 屬于 DML 支持事務回滾操作,而 truncate 和 drop 屬于 DDL,執行之后立馬生效,且數據是不可恢復的,接下來我們來驗證一下。首先先將 MySQL 的自動事務提交關閉,自動事務提交的默認值是“ON”也就是開啟了自動提交,如下圖所示:

圖片

我們使用以下命令將自動提交(事務)關掉:

set autocommit=off;

再次查詢事務自動提交的設置結果如下:

圖片

接下來我們演示一下 delete 的回滾操作,如下圖所示:

圖片

從上述結果可以看出 delete 之后是可以進行恢復(回滾)的,而 truncate 和 drop 之后是不能回滾的,各位老鐵可以使用相同的方法自行測試一下后兩種 SQL 的執行。

5.自增初始化不同

delete 不會重置自增字段的初始值,如下圖所示:

圖片

而 truncate 會重置自增字段的初始值,如下圖所示:

圖片

6.執行速度不同

delete 是逐行執行的,并且在執行時會把操作日志記錄下來,以備日后回滾使用,所以 delete 的執行速度是比較慢的;而 truncate 的操作是先復制一個新的表結構,再把原先的表整體刪除,所以它的執行速度居中,而 drop 的執行速度最快。

總結

truncate、drop 和 delete 的區別主要有以下 6 點:

  • 執行速度:drop > truncate > detele。
  • delete 和 truncate 只刪除表數據,而 drop 會刪除表數據和表結構以及表的索引、約束和觸發器。
  • delete 可以加 where 條件實現部分數據刪除,而 truncate 和 drop 不能加 where 條件是整體刪除。
  • truncate 和 drop 是立即執行,且不能恢復;而 delete 會走事務,可以撤回和恢復。
  • truncate 會重置自增列為 1,而 delete 不會重置自增列。
  • truncate 和 drop 是 DDL 語句,而 delete 是 DML 語句。
責任編輯:武曉燕 來源: Java面試真題解析
相關推薦

2022-06-08 07:34:25

InnoDBdeleteMySQL

2024-10-22 17:04:31

2020-10-21 10:30:24

deletetruncatedrop

2024-05-11 12:47:16

Kafka場景.高性能

2018-06-06 00:06:48

開源存儲存儲軟件存儲

2022-11-02 11:02:52

數據中心數據中心架構

2021-10-12 06:56:05

MYSQLDeleteDrop

2010-10-08 16:05:30

MySQL DELET

2018-04-27 14:40:18

Java語言程序

2020-11-11 14:23:35

網絡安全數據泄露網絡攻擊

2016-05-18 11:47:35

Apache大數據項目開源

2023-12-05 15:36:39

數據庫SQL

2011-06-24 10:54:37

互聯網

2023-11-26 00:26:00

2011-05-26 17:01:17

2024-10-22 14:42:14

2017-12-04 09:22:00

2016-03-17 09:46:53

2019-02-20 13:52:18

C語言語法結構程序

2022-09-06 08:07:24

SQL語句查詢
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产一区二区精品自拍 | 草草草影院 | 国产区视频在线观看 | 91精品国产色综合久久不卡蜜臀 | 北条麻妃99精品青青久久主播 | 成人毛片在线视频 | 欧美午夜一区二区三区免费大片 | 中文字幕第二十页 | 亚洲一一在线 | 亚洲视频第一页 | 日韩二区三区 | 日韩av成人| 久久久久亚洲精品 | 天天插天天射天天干 | 国产传媒毛片精品视频第一次 | 亚洲精彩视频 | 亚洲视频一区在线播放 | 亚洲www.| 亚洲精品一区二三区不卡 | 国产毛片久久久 | 99视频网站 | 99亚洲| .国产精品成人自产拍在线观看6 | 日本精品一区二区三区在线观看视频 | 国产乱码精品1区2区3区 | 亚洲人人 | 亚洲精品一区二区网址 | 久久久久久综合 | 国产福利91精品 | 国产中文字幕网 | 九九热免费看 | 欧美xxxx网站 | 国产精品久久一区二区三区 | 久久久久九九九九 | 亚洲一区中文字幕 | 国产成人在线观看免费 | 久久精品免费观看 | 98久久| 国产农村妇女精品一区 | 精品精品视频 | 亚洲高清av |