欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL 存儲(chǔ)過程的優(yōu)缺點(diǎn)分析

 更新時(shí)間:2021年05月20日 11:26:42   作者:島上碼農(nóng)  
存儲(chǔ)過程(Stored Procedure)是一種在數(shù)據(jù)庫中存儲(chǔ)復(fù)雜程序,以便外部程序調(diào)用的一種數(shù)據(jù)庫對象。本文將分析存儲(chǔ)過程的優(yōu)缺點(diǎn)

MySQL 5.0 版本開始支持存儲(chǔ)過程。存儲(chǔ)過程(Stored Procedure)是數(shù)據(jù)庫中存儲(chǔ)的復(fù)雜程序,以便外部應(yīng)用調(diào)用的一種數(shù)據(jù)庫對象。存儲(chǔ)過程是為了完成特定功能的SQL語句集,經(jīng)編譯創(chuàng)建并保存在數(shù)據(jù)庫中,用戶可通過指定存儲(chǔ)過程的名字并給定參數(shù)(可選)來調(diào)用執(zhí)行。

存儲(chǔ)過程可以有效提高 SQL 語句的復(fù)用率,并且可以將相關(guān)的一組 SQL 放入到存儲(chǔ)過程中,從而避免了應(yīng)用程序的多次查詢帶來的與 MySQL 服務(wù)器的連接延遲和占用的網(wǎng)絡(luò)資源。下面是一個(gè)存儲(chǔ)過程的示例,用于傳入一個(gè) id 來刪除指定 id的學(xué)生,并同時(shí)刪除擴(kuò)展表中的學(xué)生信息。通過這種方式就可以處理相關(guān)聯(lián)的數(shù)據(jù),而不需要應(yīng)用程序分兩次 SQL 操作。

DROP PROCEDURE IF EXISTS delete_student_by_id;

delimiter $$

CREATE PROCEDURE delete_student_by_id(IN p_id INT)
BEGIN
	DELETE FROM t_students
  WHERE id = p_id;
      
  DELETE FROM t_students_info
  WHERE student_id = p_id;
END
$$
    
delimiter ;

總的來說,存儲(chǔ)過程有如下的優(yōu)點(diǎn):

  • 直接在數(shù)據(jù)庫層運(yùn)行,從而減少網(wǎng)絡(luò)帶寬的占用和減少查詢?nèi)蝿?wù)執(zhí)行的延遲。
  • 提高了代碼的復(fù)用性和可維護(hù)性,可以聚合業(yè)務(wù)規(guī)則,加強(qiáng)一致性并提高安全性。
  • 可以帶來安全性優(yōu)勢以及優(yōu)雅的權(quán)限控制手段。一個(gè)典型的例子就是銀行中的轉(zhuǎn)賬存儲(chǔ)過程。存儲(chǔ)過程在一個(gè)事務(wù)里完成轉(zhuǎn)賬及記錄用于后續(xù)審核的完整操作日志。可以通過存儲(chǔ)過程完成訪問而無需對涉及到的表進(jìn)行提權(quán)。
  • 服務(wù)端會(huì)緩存存儲(chǔ)過程的執(zhí)行,這樣可以減少重復(fù)執(zhí)行的負(fù)荷。
  • 存儲(chǔ)過程存儲(chǔ)在服務(wù)端,因此對于服務(wù)單的部署、備份和維護(hù)而言,存儲(chǔ)過程更好維護(hù)。
  • 可以將應(yīng)用開發(fā)者與數(shù)據(jù)庫開發(fā)者的工作分離,因此可以讓數(shù)據(jù)庫牛人來寫存儲(chǔ)過程,而避免某些應(yīng)用開發(fā)者編寫 SQL水平不高的問題。

當(dāng)然,有利必有弊,存儲(chǔ)過程也會(huì)存在一些缺陷:

  • MySQL沒有提供好的開發(fā)和調(diào)試工具,因此存儲(chǔ)過程的調(diào)試相對來說不那么容易。
  • SQL 語言本身的效率沒有應(yīng)用程序的編程語言效率高,且相對更初級。因此,難以處理復(fù)雜的業(yè)務(wù)。
  • 存儲(chǔ)過程也可能增加應(yīng)用部署的復(fù)雜度,不單單需要部署應(yīng)用代碼和數(shù)據(jù)庫表,還需要部署存儲(chǔ)過程。
  • 每個(gè)連接的存儲(chǔ)過程的執(zhí)行計(jì)劃緩存是各自獨(dú)立的。如果有很多連接調(diào)用同一個(gè)存儲(chǔ)過程,反復(fù)地緩存會(huì)造成資源的浪費(fèi)。
  • 存儲(chǔ)過程將運(yùn)行符合轉(zhuǎn)移到了數(shù)據(jù)庫服務(wù)器,這會(huì)導(dǎo)致數(shù)據(jù)庫服務(wù)器的擴(kuò)容更難,且比應(yīng)用服務(wù)器的擴(kuò)容代價(jià)更高。
  • 存儲(chǔ)過程占用的資源難以控制,如果發(fā)生一個(gè) bug 可能導(dǎo)致服務(wù)器宕機(jī)。
  • 存儲(chǔ)過程的代碼很難解讀,如果單純地調(diào)用 CALL XYZ('A')這種形式調(diào)用存儲(chǔ)過程的話,很難分析慢查詢?nèi)罩尽R驗(yàn)?,這需要找到存儲(chǔ)過程的代碼并且檢查里面的語句。
  • 對于語句級的 binlog或復(fù)制,使用存儲(chǔ)過程可能會(huì)有很多陷阱導(dǎo)致無法使用存儲(chǔ)過程——除非嚴(yán)格檢查排除潛在的問題。

因此,通常,需要保持存儲(chǔ)過程小巧簡潔,以避免上述的缺陷。當(dāng)然,在某些操作時(shí),存儲(chǔ)過程會(huì)運(yùn)行得更快,尤其是在存儲(chǔ)過程中使用循環(huán)完成多個(gè)小查詢。如果查詢足夠小,解析 SQL 語句和網(wǎng)絡(luò)通信則變成了工作負(fù)荷過高的重要因素。這個(gè)時(shí)候存儲(chǔ)過程的優(yōu)勢就會(huì)被突顯出來。以下面的存儲(chǔ)過程代碼為例:

DROP PROCEDURE IF EXISTS insert_many_rows;

delemiter //

CREATE PROCEDURE insert_many_rows(IN loops INT)
BEGIN
	DECLARE v1 INT;
  SET v1=loops;
  WHILE v1 > 0 DO
  	INSERT INTO test_table values(NULL, 0,
                                 'aaaaaaaaaaaabbbbbbbbbb',
                                 'aaaaaaaaaaaabbbbbbbbbb');
    SET v1=v1-1;
  END WHILE;
END
//

delemiter ;
	

可以通過與應(yīng)用程序?qū)崿F(xiàn)同樣的功能進(jìn)行比較,發(fā)現(xiàn)使用存儲(chǔ)過程的性能提高了2倍以上,而如果與使用 MySQL 代理相比,性能會(huì)提高到3倍。

結(jié)語:存儲(chǔ)過程目前用得其實(shí)不多,但是對于一些穩(wěn)定的業(yè)務(wù),如果是因?yàn)榕c數(shù)據(jù)庫服務(wù)器之間的網(wǎng)絡(luò)請求過多或占用了大量的網(wǎng)絡(luò)帶寬,則可以考慮使用存儲(chǔ)過程來優(yōu)化性能,提高響應(yīng)速度。但是,存儲(chǔ)過程務(wù)必反復(fù)驗(yàn)證,避免出現(xiàn)意向不到的錯(cuò)誤導(dǎo)致耗費(fèi)過多的時(shí)間排查問題。

以上就是MySQL 存儲(chǔ)過程的優(yōu)缺點(diǎn)分析的詳細(xì)內(nèi)容,更多關(guān)于MySQL 存儲(chǔ)過程的優(yōu)缺點(diǎn)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 如何開啟mysql中的嚴(yán)格模式

    如何開啟mysql中的嚴(yán)格模式

    這篇文章介紹了如何開啟mysql中的嚴(yán)格模式,有需要的朋友可以參考一下
    2013-09-09
  • MySQL數(shù)據(jù)庫定時(shí)備份的實(shí)現(xiàn)方法

    MySQL數(shù)據(jù)庫定時(shí)備份的實(shí)現(xiàn)方法

    這篇文章主要介紹了MySQL數(shù)據(jù)庫的定時(shí)備份的相關(guān)知識(shí),非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-04-04
  • Mysql5.7忘記root密碼怎么辦(簡單且有效方法)

    Mysql5.7忘記root密碼怎么辦(簡單且有效方法)

    本文給大家分享一個(gè)快速且簡單的方法來解決Mysql5.7忘記root密碼問題,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2017-02-02
  • MySQL性能瓶頸排查定位實(shí)例詳解

    MySQL性能瓶頸排查定位實(shí)例詳解

    這篇文章主要介紹了MySQL性能瓶頸排查定位的方法,結(jié)合實(shí)例形式詳細(xì)分析了MySQL排查性能瓶頸問題的步驟與相關(guān)技巧,需要的朋友可以參考下
    2016-04-04
  • MySql5.6使用validate password 插件加強(qiáng)密碼強(qiáng)度的安裝及使用方法

    MySql5.6使用validate password 插件加強(qiáng)密碼強(qiáng)度的安裝及使用方法

    在mysql5.6中使用validate password插件加強(qiáng)密碼強(qiáng)度,支持密碼的強(qiáng)度要求,是一款非常好用的密碼加強(qiáng)插件,下面小編通過本文給大家介紹MySql5.6使用validate password 插件加強(qiáng)密碼強(qiáng)度的安裝及使用方法,小伙伴們一起學(xué)習(xí)吧
    2016-07-07
  • Mysql排序和分頁(order by&limit)及存在的坑

    Mysql排序和分頁(order by&limit)及存在的坑

    這篇文章主要介紹了Mysql排序和分頁(order by&limit)及存在的坑,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • MySQL查看主從狀態(tài)的命令實(shí)現(xiàn)

    MySQL查看主從狀態(tài)的命令實(shí)現(xiàn)

    本文主要介紹了MySQL查看主從狀態(tài)的命令實(shí)現(xiàn),我們可以使用SHOW SLAVE STATUS命令來查看主從狀態(tài),本文就來詳細(xì)的介紹一下如何實(shí)現(xiàn),感興趣的可以了解一下
    2023-10-10
  • MySql中的存儲(chǔ)引擎和索引

    MySql中的存儲(chǔ)引擎和索引

    這篇文章主要介紹了MySql中的存儲(chǔ)引擎和索引,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • Ubuntu?服務(wù)器安裝?MySQL?遠(yuǎn)程數(shù)據(jù)庫的方法

    Ubuntu?服務(wù)器安裝?MySQL?遠(yuǎn)程數(shù)據(jù)庫的方法

    本篇介紹如何在 Linux 服務(wù)器上安裝 MySQL 數(shù)據(jù)庫,并設(shè)置為可遠(yuǎn)程連接,本文通過命令給大家介紹的非常詳細(xì),對Ubuntu?安裝?MySQL遠(yuǎn)程數(shù)據(jù)庫感興趣的朋友一起看看吧
    2022-08-08
  • 一文解析MySQL的MVCC實(shí)現(xiàn)原理

    一文解析MySQL的MVCC實(shí)現(xiàn)原理

    這篇文章主要介紹了MySQL的MVCC實(shí)現(xiàn)原理,MVCC全稱是Multi-Version?Concurrency?Control是一種并發(fā)控制的方法,通過維護(hù)一個(gè)數(shù)據(jù)的多個(gè)版本,減少讀寫操作的沖突
    2022-08-08

最新評論