博客
关于我
Mysql_存储过程
阅读量:110 次
发布时间:2019-02-26

本文共 1233 字,大约阅读时间需要 4 分钟。

存储过程详解

一、概述

存储过程是一组用于完成特定功能的SQL语句集合。在MySQL中,从5.0版本开始支持存储过程,其优势在于可以提高数据库处理速度,增强数据库的灵活性。通过将复杂或常用的操作预先编译并存储,可以在需要时直接调用,减少客户端的负载。

二、简介

存储过程是将多条SQL语句以特定名称存储到数据库中的功能模块。其体积较小,执行效率高,适合处理复杂的数据库操作。与传统的存储过程不同,MySQL支持存储过程,可以在客户端和服务器端分别发挥作用。

三、优点

1. 提高执行效率

存储过程在第一次调用后会被编译并存储在服务器段,二进制化的代码缓存大幅度减少了执行时间。

2. 灵活性高

通过将SQL语句与控制语句结合,可以实现更复杂的逻辑操作,灵活性远超普通的SQL语句。

3. 减少网络负载

存储过程在服务器端执行,减少了客户端与数据库之间的数据传输量,提升了整体系统性能。

4. 可重复调用与维护

存储过程可以多次调用,不影响其他用户,且可以随时修改或删除,无需重启数据库。

5. 控制访问权限

通过存储过程可以对数据库操作进行严格控制,确保数据安全性。

四、示例

1. 创建不带参数的存储过程

delimiter $$create procedure cc()begin    create table mk (        id int(10),        name char(10),        score int(10)    );    insert into mk values (1, 'wang', 13);    select * from mk;end $$delimiter ;call cc();

2. 创建带参数的存储过程

delimiter $$create procedure getrole(in inname varchar(16))begin    select a_id, a_name, a_level from test1 where a_name = inname;end $$delimiter ;call getrole('aaaa');

3. 查看存储过程

show create procedure cc\G;

4. 修改存储过程

show create procedure getrole\G;alter procedure getrole modifies sql data sql security invoker;show create procedure getrole\G;

5. 删除存储过程

drop procedure if exists getrole;

五、总结

存储过程通过将复杂操作预先编译并存储,可以有效提升数据库性能和灵活性。其优势在于减少了客户端与数据库之间的交互,优化了资源利用。通过合理使用存储过程,可以显著提升系统性能,同时增强数据库的安全性和可维护性。

转载地址:http://opeu.baihongyu.com/

你可能感兴趣的文章
Objective-C实现3n+1猜想(附完整源码)
查看>>
Objective-C实现9x9乘法表算法(附完整源码)
查看>>
Objective-C实现9×9二维数组数独算法(附完整源码)
查看>>
Objective-C实现A*(A-Star)算法(附完整源码)
查看>>
Objective-C实现A-Star算法(附完整源码)
查看>>
Objective-C实现abbreviation缩写算法(附完整源码)
查看>>
Objective-C实现ABC人工蜂群算法(附完整源码)
查看>>
Objective-C实现activity selection活动选择问题算法(附完整源码)
查看>>
Objective-C实现AC算法(Aho-Corasick) 算法(附完整源码)
查看>>
Objective-C实现adaboost算法(附完整源码)
查看>>
Objective-C实现Adler32算法(附完整源码)
查看>>
Objective-C实现AES算法(附完整源码)
查看>>
Objective-C实现AffineCipher仿射密码算法(附完整源码)
查看>>
Objective-C实现aliquot sum等分求和算法(附完整源码)
查看>>
Objective-C实现all combinations所有组合算法(附完整源码)
查看>>
Objective-C实现all permutations所有排列算法(附完整源码)
查看>>
Objective-C实现all subsequences所有子序列算法(附完整源码)
查看>>
Objective-C实现AlphaNumericalSort字母数字排序算法(附完整源码)
查看>>
Objective-C实现alternate disjoint set不相交集算法(附完整源码)
查看>>
Objective-C实现alternative list arrange备选列表排列算法(附完整源码)
查看>>