在MYSQL 中终于引入了存储过程这一新特性这将大大增强MYSQL 的数据库处理能力在本文中将指导读者快速掌握MYSQL 的存储过程的基本知识带领用户入门
存储过程介绍
存储过程是一组为了完成特定功能的SQL语句集经编译后存储在数据库中用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它存储过程可由应用程序通过一个调用来执行而且允许用户声明变量 同时存储过程可以接收和输出参数返回执行存储过程的状态值也可以嵌套调用
存储过程的优点
作为存储过程有以下这些优点
()减少网络通信量调用一个行数不多的存储过程与直接调用SQL语句的网络通信量可能不会有很大的差别可是如果存储过程包含上百行SQL语句那么其性能绝对比一条一条的调用SQL语句要高得多
()执行速度更快存储过程创建的时候数据库已经对其进行了一次解析和优化其次存储过程一旦执行在内存中就会保留一份这个存储过程这样下次再执行同样的存储过程时可以从内存中直接中读取
()更强的安全性存储过程是通过向用户授予权限(而不是基于表)它们可以提供对特定数据的访问提高代码安全比如防止 SQL注入
() 业务逻辑可以封装存储过程中这样不仅容易维护而且执行效率也高
当然存储过程也有一些缺点比如
可移植性方面当从一种数据库迁移到另外一种数据库时不少的存储过程的编写要进行部分修改
存储过程需要花费一定的学习时间去学习比如学习其语法等
在MYSQL中推荐使用MYSQL Query Browswer()这个工具去进行存储过程的开发和管理下面分步骤来学习MYSQL中的存储过程
定义存储过程的结束符
在存储过程中通常要输入很多SQL语句而SQL语句中每个语句以分号来结束因此要告诉存储过程什么位置是意味着整个存储过程结束所以我们在编写存储过程前先定义分隔符我们这里定义//为分隔符我们使用DELIMITER //这样的语法就可以定义结束符了当然你可以自己定义其他喜欢的符号
如何创建存储过程
下面先看下一个简单的例子代码如下
DELIMITER//CREATEPROCEDURE`p` ()
LANGUAGE SQL
DETERMINISTIC
SQL SECURITY DEFINER
COMMENTA procedureBEGINSELECTHello World !;
END//
下面讲解下存储过程的组成部分
)首先在定义好终结符后使用CREATE PROCEDURE+存储过程名的方法创建存储过程LANGUAGE选项指定了使用的语言这里默认是使用SQL
)DETERMINISTIC关键词的作用是当确定每次的存储过程的输入和输出都是相同的内容时可以使用该关键词否则默认为NOT DETERMINISTIC
) SQL SECURITY关键词是表示调用时检查用户的权限当值为INVOKER时表示是用户调用该存储过程时检查默认为DEFINER即创建存储过程时检查
) COMMENT部分是存储过程的注释说明部分
)在BEGIN END部分中是存储过程的主体部分