MYSQL筆記:刪除操作Delete、Truncate、Drop用法比較

? ? ? ?5a382f634528da92f697c6eb7e65568f.png ? ? ? ?

今天小編給大家梳理一下MYSQL刪除操作Delete、Truncate、Drop用法有什么區別,到底該如何合理使用,希望對大家能有幫助!

1、執行速度比較

Delete、Truncate、Drop關鍵字都可以刪除數據

drop>truncate>delete

2、原理方面

2.1 delete

delete屬于數據庫DML操作語言,只會刪除數據表中的記錄,會執行事務,執行的時候也會觸發觸發器。

InnoDB數據庫引擎中,執行delete操作只會給刪除的記錄打上了刪除標記,并不會真正刪除數據,只是把刪除的數據記錄設置為不可見,不會釋放磁盤空間,如果插入新的數據可以覆蓋該部分空間。

如果開啟事務的話,執行delete操作,會先將要刪除數據緩存到rollback segement中,等事務commit之后才生效。

delete from table_name 不帶查詢條件會刪除表的全部數據,MyISAM引擎會立刻釋放磁盤空間,InnoDB 不會釋放磁盤空間;如果帶查詢條件的話都不會釋放磁盤空間,可以執行optimize table table_name 會立刻釋放磁盤空間。建議如果需要釋放存儲空間的話可以執行delete后,然后執行optimize table table_name 語句達到清理磁盤空間的目的。

-- 查詢數據庫test對應的表t_user 占用的磁盤空間
select concat(round(sum(DATA_LENGTH/1024/1024),2),'M') as table_size 
from information_schema.tables 
where table_schema='test' AND table_name='t_user';

說明:delete 操作是逐行執行刪除的,并且同時將每行的的刪除操作日志記錄在redo和undo表空間中去,便于進行回滾(rollback)和重做操作,因此生成的大量操作日志也會占用磁盤空間。

2.2 truncate

truncate是數據庫DDL定義語言,不受事務影響,也不會觸發 trigger。執行操作后會立即生效,無法找回刪除的數據。

執行truncate table table_name 會立刻釋放磁盤空間 ,不管是 InnoDB和MyISAM 都一樣 。

truncate可以退快速清空一個表。并且重置auto_increment自動增長的值。針對不同類型的數據存儲引擎是有區別的,具體如下:

MyISAM:truncate會重置auto_increment(自增序列)的值為1。而delete后表仍然保持auto_increment。

InnoDB:truncate會重置auto_increment的值為1。delete后表仍然保持auto_increment。但是在做delete整個表之后重啟MySQL的話,則重啟后的auto_increment會被置為1。

說明:InnoDB的表本身是無法持久保存auto_increment。delete表之后auto_increment仍然保存在內存,但是重啟后就找不到了,只能從1開始。實際上重啟后的auto_increment會從 SELECT 1+MAX(ai_col) FROM t 開始。

使用truncate操作的時候要最好備份表,避免出現不可挽回的情況。

2.3 drop

drop屬于數據庫DDL定義語言,和truncate一樣。執行后會立即生效,不可恢復。

drop table table_name 執行成功后不管是MyISM還是InnoDB都會立刻釋放磁盤空間 ,并且會刪除該數據表上依賴的約束(constrain)、觸發器(trigger)、索引(index); ?依賴于該表的存儲過程/函數將保留,但是會變為失效狀態。

總結

在工作當中執行數據庫刪除的時候一定要慎重再慎重,建議每次進行數據刪除的使用最好數據表的備份工作,這樣就會大大減少你刪除跑路的幾率。很多時候不要過于相信自己的動手能力,老虎還有打盹的時候,萬一手滑了呢。盡可能養成好的數據庫運維習慣,這樣會讓自己少跌跟頭,你的事業才會更加順利。

IT技術分享社區

個人博客網站:https://programmerblog.xyz

bd27521cb02333432564d9832719561d.png

文章推薦程序員效率:畫流程圖常用的工具程序員效率:整理常用的在線筆記軟件遠程辦公:常用的遠程協助軟件,你都知道嗎?51單片機程序下載、ISP及串口基礎知識硬件:斷路器、接觸器、繼電器基礎知識

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/270427.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/270427.shtml
英文地址,請注明出處:http://en.pswp.cn/news/270427.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

php常用函數

//php curl get獲取head頭部跳轉參數function get_head($sUrl){$oCurl curl_init(); // 設置請求頭, 有時候需要,有時候不用,看請求網址是否有對應的要求$header[] "Content-type: application/x-www-form-urlencoded";$user_agent "Mozilla/5.0 (Windows NT…

partition oracle用法,Oracle partition by 使用說明

--用法詳解0、select * from wmg_test; ---測試數據1、select v1,v2,sum(v2) over(order by v2) as sum --按照 v2排序,累計nn-1....1from wmg_test;2、select v1,v2,sum(v2) over(partition by v1 order by v2) as sum --先分組,組內在進行…

SQLServer優化:SQLServer中NOLOCK關鍵字的用法介紹

目錄 1、為什么SQLServer有NOLOCK關鍵字? 2、SQLServer有NOLOCK有什么問題 3、NOLOCK使用場景 4、nolock和with(nolock)的區別 5、表解鎖腳本 1、為什么SQLServer有NOLOCK關鍵字? SQLServer沒創建一個查詢,都相當于創建一個查詢會話&#xff…

20144303 20145239 實驗三

20144303 20145239 實驗三 實驗內容 1、首先連接好實驗箱電源,用串口線、并口線、網線、連接實驗箱和主機 2、安裝ADS并破解 安裝文件在00-ads1.2目錄下,破解方法在00-ads1.2\Crack目錄下 3、安裝GIVEIO驅動(安裝文件在01-GIVEIO目錄下) 把整個GIVEIO目錄…

oracle無法創建監聽器,關于Oracle net Manager中點擊無法創建監聽程序的解決方案

首先查看你的環境變量中是否有如果沒有請添加該環境變量。變量名為:TNS_ADMIN 變量值為:E:\app\Administrator\product\11.2.0\dbhome_1\NETWORK\ADMIN;(如果你更改了默認目錄,請找到相應的目錄加進去),添加完成之后,…

辦公技巧:分享5個非常好用的Excel插件

??作者主頁:IT技術分享社區 ??作者簡介:大家好,我是IT技術分享社區的博主,從事C#、Java開發九年,對數據庫、C#、Java、前端、運維、電腦技巧等經驗豐富。 ??個人榮譽: 數據庫領域優質創作者🏆&#x…

weblogic安全漫談

今天,我來與大家探討一下關于weblogic的話題 在進入內網后,如圖: 當我們看到7001時,我們就可以測試weblogic反序列化漏洞,如圖: 證明,漏洞存在,查看一下權限,如圖&#x…

linux使進程不依賴終端,Linux?nohup命令應用簡介--讓Linux的進程不受終端影響

nohup命令應用簡介--讓Linux的進程不受終端影響by:授客QQ:1033553122#開啟ping進程[rootlocalhost ~]# pinglocalhost &[2] 4169[1]Terminatednohup ping localhost[rootlocalhost ~]# PINGlocalhost (127.0.0.1) 56(84) bytes of data.64 bytes from localhost…

電腦技巧:Win10操作系統設置定時開機圖解教程

??作者主頁:IT技術分享社區 ??作者簡介:大家好,我是IT技術分享社區的博主,從事C#、Java開發九年,對數據庫、C#、Java、前端、運維、電腦技巧等經驗豐富。 ??個人榮譽: 數據庫領域優質創作者🏆&#x…

JavaScript對UNIX時間戳的轉換

<script type"text/javascript">   var timestamp 1479886513;   var d new Date(timestamp * 1000); //根據時間戳生成的時間對象   var date (d.getFullYear()) "-"     (d.getMonth() 1) "-"     (d.getDate())…

網絡技巧:想要WiFi信號滿格,路由器應該這樣放

現如今人手一部手機 不知不覺 WiFi也成了生活“必需品” 刷視頻正入迷視頻卻突然卡頓 換個房間就收不到WiFi信號 如此令人抓狂的事情 生活中你一定遇到過 其實 這與路由器的錯誤擺放有很大關系 家庭無線路由器 放置在哪里信號最好&#xff1f; WiFi信號差如何解決&#xff1f; …

linux系統export,Linux入門進階 - 如何在Linux中使用export命令

原標題&#xff1a;Linux入門進階 - 如何在Linux中使用export命令來自&#xff1a; Linux迷鏈接&#xff1a;https://www.linuxmi.com/linux-export.htmlLinux export命令會標記哪些值需要傳遞給一組子進程。這是bash shell提供的一個簡單但有用的特性。它允許管理員在不中斷當…

Duilib開發環境搭建

1.到github上下載最新版本&#xff0c;https://github.com/duilib/duilib&#xff0c;也沒有發現版本號&#xff0c;就如圖所示吧 2.我只安裝了VS2008&#xff0c;而github上的已經更新到VS2013了&#xff0c;所以要手動修改SIN工程文件 把sln文件打開&#xff0c;將最上面的2行…

手機技巧:手機丟了記住這四步操作,讓你的損失降到最低

隨著掃碼支付的普及、智慧生活的升級&#xff0c;沒有錢包能付賬&#xff0c;沒有公交卡能乘車&#xff0c;沒有銀行卡也能取款&#xff0c;只要你手機在手&#xff0c;手機手機錢包身份證銀行卡各種支付密碼。但你是否想過&#xff0c;如果某一天手機丟了&#xff0c;該怎么辦…

linux下搭建vsftp鎖定根目錄,Linux服務搭建之vsftp

安裝vsftpubuntu14.04sudo apt-get install vsftp&#xff12;&#xff0e;配置文件/etc/vsftp.congf&#xff13;&#xff0e;相關配置write-enableYES允許上傳文件local_enableYES允許/etc/passwd中記錄的用戶登錄ftp匿名用戶登錄&#xff1a;# 允許匿名用戶登錄anonymous_en…

mysql共享鎖

共享鎖 共享鎖指的就是對于多個不同的事務&#xff0c;對同一個資源共享同一個鎖。相當于對于同一把門&#xff0c;它擁有多個鑰匙一樣。就像這樣&#xff0c;你家有一個大門&#xff0c;大門的鑰匙有好幾把&#xff0c;你有一把&#xff0c;你女朋友有一把&#xff0c;你們都…

YII2 隨筆 視圖最佳實踐

yii\base\Controller::render(): 渲染一個 視圖名 并使用一個 布局 返回到渲染結果。yii\base\Controller::renderPartial(): 渲染一個 視圖名 并且不使用布局。yii\web\Controller::renderAjax(): 渲染一個 視圖名 并且不使用布局&#xff0c; 并注入所有注冊的JS/CSS腳本和文…

網絡技巧:無線路由器越用越慢的解決方法

目錄 01 ???????路由器越用越慢很平常 02 國區設置不要亂用 03 很容易被遺忘的IPv6設置 04 學會自我檢查掉線問題 05 番外篇&#xff1a;測試自己的網速 “耳機、音箱通過一定時間的煲機&#xff0c;表現效果會變好&#xff0c;可為何家里WiFi網絡卻老是給人越用越慢、越…