一、SQL語言中的ALTER和UPDATE,DROP和DELETE的區(qū)別
1、刪除內(nèi)容:drop操作會(huì)刪除表結(jié)構(gòu)、依賴的約束、索引以及觸發(fā)器,并且會(huì)將依賴該表的所有存儲(chǔ)過程和視圖設(shè)置為invalid;而truncate和delete則是只會(huì)刪除表中的數(shù)據(jù),并不會(huì)刪除表結(jié)構(gòu)。因此如果該表以后不再需要的話可以使用drop,而如果后續(xù)還需要的話可以通過truncate或delete,因?yàn)檫@樣可以不需要再重新建立表。
2、刪除空間:delete操作并不會(huì)更改所占用的區(qū)的空間,高水位線不會(huì)發(fā)生改變。drop操作就會(huì)直接刪除整個(gè)表空間,而執(zhí)行truncate則是相對(duì)于先執(zhí)行drop操作,然后在執(zhí)行create操作,執(zhí)行完成后會(huì)恢復(fù)初始的表空間。
3、語句類型:delete 語句是DML語句,這個(gè)操作會(huì)放到 rollback segement 中,事務(wù)提交之后才生效;并且可以執(zhí)行對(duì)應(yīng)的觸發(fā)器。但truncate、drop是DDL操作,會(huì)包含implicit commit,因此不能回滾,也不能不觸發(fā)觸發(fā)器。
4、效率:從第二點(diǎn)的描述中可以推斷truncate的執(zhí)行效率要低于drop操作;而delete操作則是按照行記錄一行一行的進(jìn)行刪除,因此其效率更低。
5、安全性:使用 drop 和 truncate會(huì)導(dǎo)致整個(gè)表中的數(shù)據(jù)都被刪除,需格外注意。如果僅想刪除部分?jǐn)?shù)據(jù)可用delete,但是需要注意where子句得到的范圍,會(huì)占用rollback segement。
延伸閱讀:
二、為什么要持久化連接
這和 web 服務(wù)器的工作方式有關(guān)。web 服務(wù)器可以通過三種方法來利用 PHP 生成 web 頁面。
名列前茅種方法是將 PHP 自以為 CGI“包裝器”用作一個(gè)單獨(dú)運(yùn)行的語言解釋器(CGI Wapper)。當(dāng)以這種方法運(yùn)行時(shí),PHP 會(huì)為向 web 服務(wù)器的每個(gè) PHP 頁面請(qǐng)求創(chuàng)建并銷毀 PHP 解釋器的時(shí)候?qū)嵗?。由于其?huì)隨每個(gè)請(qǐng)求的結(jié)束而銷毀,因此其獲取的任何資源(例如指向 SQL 數(shù)據(jù)庫服務(wù)器的鏈接)都會(huì)在銷毀時(shí)關(guān)閉。在這種情況下,不會(huì)從使用持久連接中獲得任何好處——因?yàn)楦静粫?huì)持久。
第二,也是最流行的方法是把 PHP 用作多進(jìn)程 web 服務(wù)器的一個(gè)模塊,這種方法目前只適用于 Apache。多進(jìn)程的服務(wù)器通常有一個(gè)父進(jìn)程和一組子進(jìn)程協(xié)調(diào)運(yùn)行,子進(jìn)程負(fù)責(zé)提供網(wǎng)頁的工作。每當(dāng)接收達(dá)到客戶端提出請(qǐng)求時(shí),該請(qǐng)求會(huì)傳遞給尚未給其它客戶端提供服務(wù)的某個(gè)子進(jìn)程。這也就是說當(dāng)相同的客戶端第二次向服務(wù)端發(fā)出請(qǐng)求時(shí),它將有可能由與名列前茅次不同的某個(gè)子進(jìn)程提供服務(wù)。在開啟了一個(gè)持久連接后,所有請(qǐng)求 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ù)器的插件使用。該行為與前面描述的多過程模型相同。