一、SQL語言中的ALTER和UPDATE,DROP和DELETE的區別
1、刪除內容:drop操作會刪除表結構、依賴的約束、索引以及觸發器,并且會將依賴該表的所有存儲過程和視圖設置為invalid;而truncate和delete則是只會刪除表中的數據,并不會刪除表結構。因此如果該表以后不再需要的話可以使用drop,而如果后續還需要的話可以通過truncate或delete,因為這樣可以不需要再重新建立表。
2、刪除空間:delete操作并不會更改所占用的區的空間,高水位線不會發生改變。drop操作就會直接刪除整個表空間,而執行truncate則是相對于先執行drop操作,然后在執行create操作,執行完成后會恢復初始的表空間。
3、語句類型:delete 語句是DML語句,這個操作會放到 rollback segement 中,事務提交之后才生效;并且可以執行對應的觸發器。但truncate、drop是DDL操作,會包含implicit commit,因此不能回滾,也不能不觸發觸發器。
4、效率:從第二點的描述中可以推斷truncate的執行效率要低于drop操作;而delete操作則是按照行記錄一行一行的進行刪除,因此其效率更低。
5、安全性:使用 drop 和 truncate會導致整個表中的數據都被刪除,需格外注意。如果僅想刪除部分數據可用delete,但是需要注意where子句得到的范圍,會占用rollback segement。
延伸閱讀:
二、為什么要持久化連接
這和 web 服務器的工作方式有關。web 服務器可以通過三種方法來利用 PHP 生成 web 頁面。
名列前茅種方法是將 PHP 自以為 CGI“包裝器”用作一個單獨運行的語言解釋器(CGI Wapper)。當以這種方法運行時,PHP 會為向 web 服務器的每個 PHP 頁面請求創建并銷毀 PHP 解釋器的時候實例。由于其會隨每個請求的結束而銷毀,因此其獲取的任何資源(例如指向 SQL 數據庫服務器的鏈接)都會在銷毀時關閉。在這種情況下,不會從使用持久連接中獲得任何好處——因為根本不會持久。
第二,也是最流行的方法是把 PHP 用作多進程 web 服務器的一個模塊,這種方法目前只適用于 Apache。多進程的服務器通常有一個父進程和一組子進程協調運行,子進程負責提供網頁的工作。每當接收達到客戶端提出請求時,該請求會傳遞給尚未給其它客戶端提供服務的某個子進程。這也就是說當相同的客戶端第二次向服務端發出請求時,它將有可能由與名列前茅次不同的某個子進程提供服務。在開啟了一個持久連接后,所有請求 SQL 服務的后繼頁面都能夠重用與 SQL 服務器建立的相同連接。
最后一種方法是將 PHP 用作多線程 web 服務器的插件。目前 PHP 支持 WSAPI 和 NSAPI(在 Windows 上),允許 PHP 作為 Netscape FastTrack(iPlanet)、Microsoft 的 Internet Information Server (IIS) 和 O’Reilly 的 WebSite Pro 等多線程服務器的插件使用。該行為與前面描述的多過程模型相同。