mysql從5.0版開始支持存儲過程。MySQL5.0版本以前并不支持存儲過程,這使MySQL在應用上大打折扣。MySQL從5.0版本開始支持存儲過程,既提高了數據庫的處理速度,同時也提高了數據庫編程的靈活性。
本教程操作環(huán)境:windows7系統(tǒng)、mysql8版本、Dell G3電腦。
MySQL 5.0 版本開始支持存儲過程。
存儲過程(Stored Procedure)是一種在數據庫中存儲復雜程序,以便外部程序調用的一種數據庫對象。
存儲過程是為了完成特定功能的SQL語句集,經編譯創(chuàng)建并保存在數據庫中,用戶可通過指定存儲過程的名字并給定參數(需要時)來調用執(zhí)行。
存儲過程思想上很簡單,就是數據庫 SQL 語言層面的代碼封裝與重用。
使用存儲過程不僅可以提高數據庫的訪問效率,同時也可以提高數據庫使用的安全性。
對于調用者來說,存儲過程封裝了 SQL 語句,調用者無需考慮邏輯功能的具體實現過程。只是簡單調用即可,它可以被 Java 和 C# 等編程語言調用。
(推薦教程:mysql視頻教程)
編寫存儲過程對開發(fā)者要求稍微高一些,但這并不影響存儲過程的普遍使用,因為存儲過程有如下優(yōu)點:
1) 封裝性
通常完成一個邏輯功能需要多條 SQL 語句,而且各個語句之間很可能傳遞參數,所以,編寫邏輯功能相對來說稍微復雜些,而存儲過程可以把這些 SQL 語句包含到一個獨立的單元中,使外界看不到復雜的 SQL 語句,只需要簡單調用即可達到目的。并且數據庫專業(yè)人員可以隨時對存儲過程進行修改,而不會影響到調用它的應用程序源代碼。
2) 可增強 SQL 語句的功能和靈活性
存儲過程可以用流程控制語句編寫,有很強的靈活性,可以完成復雜的判斷和較復雜的運算。
3) 可減少網絡流量
由于存儲過程是在服務器端運行的,且執(zhí)行速度快,因此當客戶計算機上調用該存儲過程時,網絡中傳送的只是該調用語句,從而可降低網絡負載。
4) 高性能
當存儲過程被成功編譯后,就存儲在數據庫服務器里了,以后客戶端可以直接調用,這樣所有的 SQL 語句將從服務器執(zhí)行,從而提高性能。但需要說明的是,存儲過程不是越多越好,過多的使用存儲過程反而影響系統(tǒng)性能。
5) 提高數據庫的安全性和數據的完整性
存儲過程提高安全性的一個方案就是把它作為中間組件,存儲過程里可以對某些表做相關操作,然后存儲過程作為接口提供給外部程序。這樣,外部程序無法直接操作數據庫表,只能通過存儲過程來操作對應的表,因此在一定程度上,安全性是可以得到提高的。
6) 使數據獨立
數據的獨立可以達到解耦的效果,也就是說,程序可以調用存儲過程,來替代執(zhí)行多條的 SQL 語句。這種情況下,存儲過程把數據同用戶隔離開來,優(yōu)點就是當數據表的結構改變時,調用表不用修改程序,只需要數據庫管理者重新編寫存儲過程即可。