久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

mysql有存儲過程嗎

135次閱讀
沒有評論

共計 2843 個字符,預計需要花費 8 分鐘才能閱讀完成。

這篇文章主要介紹“mysql 有存儲過程嗎”,在日常操作中,相信很多人在 mysql 有存儲過程嗎問題上存在疑惑,丸趣 TV 小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”mysql 有存儲過程嗎”的疑惑有所幫助!接下來,請跟著丸趣 TV 小編一起來學習吧!

mysql 有存儲過程。存儲過程是一組為了完成特定功能的 SQL 語句集合,MySQL5.0 版本以前不支持存儲過程,但從 5.0 版本開始支持存儲過程,這樣既提高了數據庫的處理速度,同時也提高了數據庫編程的靈活性。存儲過程可以用來轉換數據、數據遷移、制作報表,它類似于編程語言,一次執行成功,就可以隨時被調用,完成指定的功能操作。

本教程操作環境:windows7 系統、mysql8 版本、Dell G3 電腦。

mysql 有存儲過程。

存儲過程是一組為了完成特定功能的 SQL 語句集合。使用存儲過程的目的是將常用或復雜的工作預先用 SQL 語句寫好并用一個指定名稱存儲起來,這個過程經編譯和優化后存儲在數據庫服務器中,因此稱為存儲過程。當以后需要數據庫提供與已定義好的存儲過程的功能相同的服務時,只需調用“CALL 存儲過程名字”即可自動完成。

常用操作數據庫的 SQL 語句在執行的時候需要先編譯,然后執行。存儲過程則采用另一種方式來執行 SQL 語句。

一個存儲過程是一個可編程的函數,它在數據庫中創建并保存,一般由 SQL 語句和一些特殊的控制結構組成。當希望在不同的應用程序或平臺上執行相同的特定功能時,存儲過程尤為合適。

MySQL 5.0 版本以前并不支持存儲過程,這使 MySQL 在應用上大打折扣。MySQL 從 5.0 版本開始支持存儲過程,既提高了數據庫的處理速度,同時也提高了數據庫編程的靈活性

存儲過程是數據庫中的一個重要功能,存儲過程可以用來轉換數據、數據遷移、制作報表,它類似于編程語言,一次執行成功,就可以隨時被調用,完成指定的功能操作。

使用存儲過程不僅可以提高數據庫的訪問效率,同時也可以提高數據庫使用的安全性。

對于調用者來說,存儲過程封裝了 SQL 語句,調用者無需考慮邏輯功能的具體實現過程。只是簡單調用即可,它可以被 Java 和 C# 等編程語言調用。

編寫存儲過程對開發者要求稍微高一些,但這并不影響存儲過程的普遍使用,因為存儲過程有如下優點:

1) 封裝性

通常完成一個邏輯功能需要多條 SQL 語句,而且各個語句之間很可能傳遞參數,所以,編寫邏輯功能相對來說稍微復雜些,而存儲過程可以把這些 SQL 語句包含到一個獨立的單元中,使外界看不到復雜的 SQL 語句,只需要簡單調用即可達到目的。并且數據庫專業人員可以隨時對存儲過程進行修改,而不會影響到調用它的應用程序源代碼。

2) 可增強 SQL 語句的功能和靈活性

存儲過程可以用流程控制語句編寫,有很強的靈活性,可以完成復雜的判斷和較復雜的運算。

3) 可減少網絡流量

由于存儲過程是在服務器端運行的,且執行速度快,因此當客戶計算機上調用該存儲過程時,網絡中傳送的只是該調用語句,從而可降低網絡負載。

4) 高性能

當存儲過程被成功編譯后,就存儲在數據庫服務器里了,以后客戶端可以直接調用,這樣所有的 SQL 語句將從服務器執行,從而提高性能。但需要說明的是,存儲過程不是越多越好,過多的使用存儲過程反而影響系統性能。

5) 提高數據庫的安全性和數據的完整性

存儲過程提高安全性的一個方案就是把它作為中間組件,存儲過程里可以對某些表做相關操作,然后存儲過程作為接口提供給外部程序。這樣,外部程序無法直接操作數據庫表,只能通過存儲過程來操作對應的表,因此在一定程度上,安全性是可以得到提高的。

6) 使數據獨立

數據的獨立可以達到解耦的效果,也就是說,程序可以調用存儲過程,來替代執行多條的 SQL 語句。這種情況下,存儲過程把數據同用戶隔離開來,優點就是當數據表的結構改變時,調用表不用修改程序,只需要數據庫管理者重新編寫存儲過程即可。

MySQL 存儲過程實例

我們將逐步向您展示如何使用 CREATE PROCEDURE 開發第一個 MySQL 存儲過程。此外,我們將向您展示如何從 SQL 語句調用存儲過程。

編寫第一個 MySQL 存儲過程

我們將開發一個簡單的存儲過程,以 GetAllProducts()   幫助您熟悉語法。GetAllProducts()   存儲過程選擇所有產品從 products 表。

啟動 mysql 客戶端工具并鍵入以下命令:

 DELIMITER //
 CREATE PROCEDURE GetAllProducts()
 BEGIN
 SELECT productCode, productName FROM products;
 END //
 DELIMITER ;

執行命令:

mysql  DELIMITER //
mysql  CREATE PROCEDURE GetAllProducts()
-  BEGIN
-  SELECT productCode, productName FROM products;
-  END //
Query OK, 0 rows affected (0.02 sec)
mysql  DELIMITER ;

讓我們更詳細地檢查存儲過程:

第一個命令是 DELIMITER //,與存儲過程語法無關。DELIMITER 語句將標準分隔符(分號(;)更改為另一個分號)。在這種情況下,分隔符從分號(;)更改為雙斜線 //。為什么我們要更改分隔符?因為我們希望將存儲過程作為一個整體傳遞給服務器,而不是讓 mysql 工具一次解釋每個語句。在 END 關鍵字之后,我們使用分隔符 //   來指示存儲過程的結束。最后一個命令(DELIMITER;)將分隔符更改回分號(;)。

我們使用 CREATE PROCEDURE   語句來創建一個新的存儲過程。我們在 CREATE PROCEDURE   語句后指定存儲過程的名稱。在這種情況下,存儲過程的名稱是 GetAllProducts。我們將括號放在存儲過程的名稱之后。

BEGIN 和之間的部分  END   稱為存儲過程的主體。您將聲明性 SQL 語句放在正文中以處理業務邏輯。在這個存儲過程中,我們使用一個簡單的 SELECT 語句來查詢 products 表中的數據。

查看存儲過程

我們可以使用如下命令查看指定的數據庫中有哪些存儲過程:

 select name from mysql.proc where db= mysqldemo

運行結果:

調用存儲過程

要調用存儲過程,請使用以下 SQL 命令:

CALL stored_procedure_name();

您使用 CALL 語句調用存儲過程,例如,要調用 GetAllProducts() 存儲過程,請使用以下語句:

CALL GetAllProducts();

如果執行上述語句,您將獲得 products 表中的所有產品。

到此,關于“mysql 有存儲過程嗎”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注丸趣 TV 網站,丸趣 TV 小編會繼續努力為大家帶來更多實用的文章!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-07-13發表,共計2843字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 成都市| 信阳市| 子长县| 延寿县| 增城市| 墨玉县| 佛坪县| 蒲城县| 普宁市| 鄢陵县| 安图县| 错那县| 佳木斯市| 黄平县| 舞钢市| 焉耆| 涞水县| 慈利县| 榕江县| 额济纳旗| 井冈山市| 望城县| 邵东县| 三穗县| 大邑县| 莒南县| 诸城市| 珠海市| 郸城县| 荥阳市| 南城县| 灌南县| 讷河市| 板桥市| 仁布县| 建始县| 武川县| 庆阳市| 南华县| 德化县| 邢台市|