日期:2014-05-16 浏览次数:20765 次
引用自:
http://blog.csdn.net/tianyazaiheruan/article/details/7658139
?
1. ? 使用存储过程的优点有:
(1)存储过程在服务器端运行,执行速度快。
(2)存储过程执行一次后,其执行规划就驻留在高速缓冲存储器,在以后的操作中,只需从高速缓冲存储器中调用已编译好的二进制代码执行,提高了系统性能。
(3)确保数据库的安全。使用存储过程可以完成所有数据库操作,并可通过编程方式控制上述操作对数据库信息访问的权限。
2. 创建存储过程可以使用create procedure 语句。
要在MySQL 5.1中创建存储过程,必须具有CREATE routine权限。要想查看数据库中有哪些存储过程,可以使用SHOW PROCEDURE STATUS命令。要查看某个存储过程的具体信息,可使用SHOWCREATE PROCEDURE sp_name命令,其中sp_name是存储过程的名称。
CREATE PROCEDURE的语法格式:
CREATE PROCEDURE sp_name ([proc_parameter[,...]])
???[characteristic ...] routine_body
其中,proc_parameter的参数如下:
[ IN | OUT | INOUT ] param_name type
characteristic特征如下:
??language SQL
?| [NOT] DETERMINISTIC
?| { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
?| SQL SECURITY { DEFINER | INVOKER }
?| COMMENT 'string'
说明:
●?? sp_name:存储过程的名称,默认在当前数据库中创建。需要在特定数据库中创建存储过程时,则要在名称前面加上数据库的名称,格式为:db_name.sp_name。值得注意的是,这个名称应当尽量避免取与MySQL的内置函数相同的名称,否则会发生错误。
?●?? proc_parameter:存储过程的参数,param_name为参数名,type为参数的类型,当有多个参数的时候中间用逗号隔开。存储过程可以 有0个、1个或多个参数。MySQL存储过程支持三种类型的参数:输入参数、输出参数和输入/输出参数,关键字分别是IN、OUT和INOUT。输入参数使数据可以传递给一个存储过程。当需要返回一个答案或结果的时候,存储过程使用输出参数。输入/ 输出参数既可以充当输入参数也可以充当输出参数。存储过程也可以不加参数,但是名称后面的括号是不可省略的 。
注意: 参数的名字不要等于列的名字,否则虽然不会返回出错消息,但是存储过程中的SQL语句会将参数名看做列名,从而引发不可预知的结果。
characteristic :存储过程的某些特征设定,下面一一介绍 :
language sql : 表明编写这个存储过程的语言为SQL 语言,目前来讲,MySQL存储过程还不能用外部编程语言来编写,也就是说,这个选项可以不指定。将来将会对其扩展,最有可能第一个被支持的语言是PHP 。
deterministic : 设置为DETERMINISTIC表示存储过程对同样的输入参数产生相同的结果 ,设置为NOT DETERMINISTIC则表示会产生不确定的结果。默认为NOTDETERMINISTIC。
contains SQL : 表示存储过程不包含读或写数据的语句 。NO SQL表示存储过程不包含SQL语句。reads SQL DATA表示存储过程包含读数据的语句,但不包含写数据的语句。modifies SQL DATA表示存储过程包含写数据的语句。如果这些特征没有明确给定,默认的是CONTAINS SQL 。
SQL SECURITY:SQL SECURITY特征可以用来指定存储过程使用创建该存储过程的用户(DEFINER)的许可来执行,还是使用调用者(INVOKER)的许可来执行。默认值是DEFINER。