国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

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

手機站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > SQL語言中的ALTER和UPDATE,DROP和DELETE都有什么區(qū)別?

SQL語言中的ALTER和UPDATE,DROP和DELETE都有什么區(qū)別?

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-10-13 15:08:06 1697180886

一、SQL語言中的ALTER和UPDATE,DROP和DELETE的區(qū)別

1、刪除內(nèi)容:drop操作會刪除表結(jié)構(gòu)、依賴的約束、索引以及觸發(fā)器,并且會將依賴該表的所有存儲過程和視圖設(shè)置為invalid;而truncate和delete則是只會刪除表中的數(shù)據(jù),并不會刪除表結(jié)構(gòu)。因此如果該表以后不再需要的話可以使用drop,而如果后續(xù)還需要的話可以通過truncate或delete,因為這樣可以不需要再重新建立表。

2、刪除空間:delete操作并不會更改所占用的區(qū)的空間,高水位線不會發(fā)生改變。drop操作就會直接刪除整個表空間,而執(zhí)行truncate則是相對于先執(zhí)行drop操作,然后在執(zhí)行create操作,執(zhí)行完成后會恢復(fù)初始的表空間。

3、語句類型:delete 語句是DML語句,這個操作會放到 rollback segement 中,事務(wù)提交之后才生效;并且可以執(zhí)行對應(yīng)的觸發(fā)器。但truncate、drop是DDL操作,會包含implicit commit,因此不能回滾,也不能不觸發(fā)觸發(fā)器。

4、效率:從第二點的描述中可以推斷truncate的執(zhí)行效率要低于drop操作;而delete操作則是按照行記錄一行一行的進行刪除,因此其效率更低。

5、安全性:使用 drop 和 truncate會導(dǎo)致整個表中的數(shù)據(jù)都被刪除,需格外注意。如果僅想刪除部分數(shù)據(jù)可用delete,但是需要注意where子句得到的范圍,會占用rollback segement。

延伸閱讀:

二、為什么要持久化連接

這和 web 服務(wù)器的工作方式有關(guān)。web 服務(wù)器可以通過三種方法來利用 PHP 生成 web 頁面。

名列前茅種方法是將 PHP 自以為 CGI“包裝器”用作一個單獨運行的語言解釋器(CGI Wapper)。當(dāng)以這種方法運行時,PHP 會為向 web 服務(wù)器的每個 PHP 頁面請求創(chuàng)建并銷毀 PHP 解釋器的時候?qū)嵗S捎谄鋾S每個請求的結(jié)束而銷毀,因此其獲取的任何資源(例如指向 SQL 數(shù)據(jù)庫服務(wù)器的鏈接)都會在銷毀時關(guān)閉。在這種情況下,不會從使用持久連接中獲得任何好處——因為根本不會持久。

第二,也是最流行的方法是把 PHP 用作多進程 web 服務(wù)器的一個模塊,這種方法目前只適用于 Apache。多進程的服務(wù)器通常有一個父進程和一組子進程協(xié)調(diào)運行,子進程負責(zé)提供網(wǎng)頁的工作。每當(dāng)接收達到客戶端提出請求時,該請求會傳遞給尚未給其它客戶端提供服務(wù)的某個子進程。這也就是說當(dāng)相同的客戶端第二次向服務(wù)端發(fā)出請求時,它將有可能由與名列前茅次不同的某個子進程提供服務(wù)。在開啟了一個持久連接后,所有請求 SQL 服務(wù)的后繼頁面都能夠重用與 SQL 服務(wù)器建立的相同連接。

最后一種方法是將 PHP 用作多線程 web 服務(wù)器的插件。目前 PHP 支持 WSAPI 和 NSAPI(在 Windows 上),允許 PHP 作為 Netscape FastTrack(iPlanet)、Microsoft 的 Internet Information Server (IIS) 和 O’Reilly 的 WebSite Pro 等多線程服務(wù)器的插件使用。該行為與前面描述的多過程模型相同。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
如何建立數(shù)據(jù)庫,利用什么軟件建立數(shù)據(jù)庫?

一、如何建立數(shù)據(jù)庫CREATE DATABASE:MySQL語法示例應(yīng)該提到的在MySQL中創(chuàng)建數(shù)據(jù)庫的名列前茅種方法是使用CREATE DATABASE語句。該語句以指定的...詳情>>

2023-10-13 16:56:43
為什么使用Redis做緩存而不會使用關(guān)系型數(shù)據(jù)庫?

一、為什么使用Redis做緩存而不會使用關(guān)系型數(shù)據(jù)庫首先要知道緩存緩存是干什么的,緩存是指可以進行高速數(shù)據(jù)交換的存儲器,它先于內(nèi)存與CPU交換...詳情>>

2023-10-13 16:43:22
mysql 非少數(shù)索引的等值查詢?yōu)槭裁匆觛ap鎖?

一、mysql 非少數(shù)索引的等值查詢?yōu)槭裁匆觛ap鎖mysql 中非少數(shù)索引使用的也是 B+ 樹來組織數(shù)據(jù)結(jié)構(gòu)。假設(shè) id 的索引結(jié)構(gòu)在葉子節(jié)點從左到右的...詳情>>

2023-10-13 16:33:11
mongoDB和python連接處理數(shù)據(jù)慢怎么解決?

一、mongoDB和python連接處理數(shù)據(jù)慢怎么解決mongoDB和python連接處理數(shù)據(jù)慢可以考慮用并行計算,單機多線程并行,或者集群并行。集算器提供封裝...詳情>>

2023-10-13 16:29:19
MySQL DDL會鎖表不能寫,怎么保證持續(xù)讀寫呢?

一、MySQL DDL會鎖表不能寫,怎么保證持續(xù)讀寫比較笨的方法通常就是最常用的方法。搞一個臨時表,新數(shù)據(jù)寫兩份,舊數(shù)據(jù)分段導(dǎo)入臨時表。舊數(shù)據(jù)...詳情>>

2023-10-13 16:26:29
快速通道