电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

MySQL 存儲過程的優缺點分析

瀏覽:3日期:2023-10-02 17:34:53

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

存儲過程可以有效提高 SQL 語句的復用率,并且可以將相關的一組 SQL 放入到存儲過程中,從而避免了應用程序的多次查詢帶來的與 MySQL 服務器的連接延遲和占用的網絡資源。下面是一個存儲過程的示例,用于傳入一個 id 來刪除指定 id的學生,并同時刪除擴展表中的學生信息。通過這種方式就可以處理相關聯的數據,而不需要應用程序分兩次 SQL 操作。

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

總的來說,存儲過程有如下的優點:

直接在數據庫層運行,從而減少網絡帶寬的占用和減少查詢任務執行的延遲。 提高了代碼的復用性和可維護性,可以聚合業務規則,加強一致性并提高安全性。 可以帶來安全性優勢以及優雅的權限控制手段。一個典型的例子就是銀行中的轉賬存儲過程。存儲過程在一個事務里完成轉賬及記錄用于后續審核的完整操作日志。可以通過存儲過程完成訪問而無需對涉及到的表進行提權。 服務端會緩存存儲過程的執行,這樣可以減少重復執行的負荷。 存儲過程存儲在服務端,因此對于服務單的部署、備份和維護而言,存儲過程更好維護。 可以將應用開發者與數據庫開發者的工作分離,因此可以讓數據庫牛人來寫存儲過程,而避免某些應用開發者編寫 SQL水平不高的問題。

當然,有利必有弊,存儲過程也會存在一些缺陷:

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

因此,通常,需要保持存儲過程小巧簡潔,以避免上述的缺陷。當然,在某些操作時,存儲過程會運行得更快,尤其是在存儲過程中使用循環完成多個小查詢。如果查詢足夠小,解析 SQL 語句和網絡通信則變成了工作負荷過高的重要因素。這個時候存儲過程的優勢就會被突顯出來。以下面的存儲過程代碼為例:

DROP PROCEDURE IF EXISTS insert_many_rows;delemiter //CREATE PROCEDURE insert_many_rows(IN loops INT)BEGINDECLARE 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 ;

可以通過與應用程序實現同樣的功能進行比較,發現使用存儲過程的性能提高了2倍以上,而如果與使用 MySQL 代理相比,性能會提高到3倍。

結語:存儲過程目前用得其實不多,但是對于一些穩定的業務,如果是因為與數據庫服務器之間的網絡請求過多或占用了大量的網絡帶寬,則可以考慮使用存儲過程來優化性能,提高響應速度。但是,存儲過程務必反復驗證,避免出現意向不到的錯誤導致耗費過多的時間排查問題。

以上就是MySQL 存儲過程的優缺點分析的詳細內容,更多關于MySQL 存儲過程的優缺點的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 成都LED显示屏丨室内户外全彩led屏厂家方案报价_四川诺显科技 | 中视电广_短视频拍摄_短视频推广_短视频代运营_宣传片拍摄_影视广告制作_中视电广 | 电气控制系统集成商-PLC控制柜变频控制柜-非标自动化定制-电气控制柜成套-NIDEC CT变频器-威肯自动化控制 | 青岛球场围网,青岛车间隔离网,青岛机器人围栏,青岛水源地围网,青岛围网,青岛隔离栅-青岛晟腾金属制品有限公司 | 扫地车厂家-山西洗地机-太原电动扫地车「大同朔州吕梁晋中忻州长治晋城洗地机」山西锦力环保科技有限公司 | 郑州水质检测中心_井水检测_河南废气检测_河南中环嘉创检测 | 进口便携式天平,外校_十万分之一分析天平,奥豪斯工业台秤,V2000防水秤-重庆珂偌德科技有限公司(www.crdkj.com) | 电主轴-高速精密电主轴-高速电机厂家-瑞德沃斯品牌有限公司 | 旅游规划_旅游策划_乡村旅游规划_景区规划设计_旅游规划设计公司-北京绿道联合旅游规划设计有限公司 | 紫外可见光分光度计-紫外分光度计-分光光度仪-屹谱仪器制造(上海)有限公司 | 微波消解仪器_智能微波消解仪报价_高压微波消解仪厂家_那艾 | 广州昊至泉水上乐园设备有限公司| 破碎机锤头_耐磨锤头_合金锤头-鼎成机械一站式耐磨铸件定制服务 微型驱动系统解决方案-深圳市兆威机电股份有限公司 | 上海防爆真空干燥箱-上海防爆冷库-上海防爆冷柜?-上海浦下防爆设备厂家? | 全球化工设备网—化工设备,化工机械,制药设备,环保设备的专业网络市场。 | 「阿尔法设计官网」工业设计_产品设计_产品外观设计 深圳工业设计公司 | 合肥汽车充电桩_安徽充电桩_电动交流充电桩厂家_安徽科帝新能源科技有限公司 | 缝纫客| 高清视频编码器,4K音视频编解码器,直播编码器,流媒体服务器,深圳海威视讯技术有限公司 | 合肥角钢_合肥槽钢_安徽镀锌管厂家-昆瑟商贸有限公司 | 气动隔膜泵厂家-温州永嘉定远泵阀有限公司 | 超声波破碎仪-均质乳化机(供应杭州,上海,北京,广州,深圳,成都等地)-上海沪析实业有限公司 | 北京开业庆典策划-年会活动策划公司-舞龙舞狮团大鼓表演-北京盛乾龙狮鼓乐礼仪庆典策划公司 | 无水硫酸铝,硫酸铝厂家-淄博双赢新材料科技有限公司 | 天空彩票天下彩,天空彩天空彩票免费资料,天空彩票与你同行开奖,天下彩正版资料大全 | 武汉天安盾电子设备有限公司 - 安盾安检,武汉安检门,武汉安检机,武汉金属探测器,武汉测温安检门,武汉X光行李安检机,武汉防爆罐,武汉车底安全检查,武汉液体探测仪,武汉安检防爆设备 | 识禅_对禅的了解,从这里开始| 微型驱动系统解决方案-深圳市兆威机电股份有限公司 | 电杆荷载挠度测试仪-电杆荷载位移-管桩测试仪-北京绿野创能机电设备有限公司 | 【中联邦】增稠剂_增稠粉_水性增稠剂_涂料增稠剂_工业增稠剂生产厂家 | 吲哚菁绿衍生物-酶底物法大肠菌群检测试剂-北京和信同通科技发展有限公司 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | 气体热式流量计-定量控制流量计(空气流量计厂家)-湖北南控仪表科技有限公司 | 超声波清洗机_超声波清洗机设备_超声波清洗机厂家_鼎泰恒胜 | 锂辉石检测仪器,水泥成分快速分析仪-湘潭宇科分析仪器有限公司 | 超声骨密度仪,双能X射线骨密度仪【起草单位】,骨密度检测仪厂家 - 品源医疗(江苏)有限公司 | 高压微雾加湿器_工业加湿器_温室喷雾-昌润空气净化设备 | 电线电缆厂家|沈阳电缆厂|电线厂|沈阳英联塑力线缆有限公司 | 自清洗过滤器_全自动过滤器_全自动反冲洗过滤器_量子过滤器-滑漮滴 | 网带通过式抛丸机,,网带式打砂机,吊钩式,抛丸机,中山抛丸机生产厂家,江门抛丸机,佛山吊钩式,东莞抛丸机,中山市泰达自动化设备有限公司 | 沥青灌缝机_路面灌缝机_道路灌缝机_沥青灌缝机厂家_济宁萨奥机械有限公司 |