存储过程

1. 概念: 存储过程是一个预编译的SQL语句,优点是允许模块化的设计,就是说只需要创建一次,以后再改程序中可以调用多次。如果某次操作需要执行多次SQL,使用存储过程就比单纯的SQL语句执行要快。

2. 优点: 

  存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。

  当对数据库进行复杂操作时(如对多个表进行Update,Insert,Query,Delete时),可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。
  存储过程可以重复使用,可减少数据库开发人员的工作量
  安全性高,可设定只有某些用户才具有对指定存储过程的使用权

3. 缺点:

  调试麻烦,但是用 PL/SQL Developer 调试很方便!弥补这个缺点。

  移植问题,数据库端代码当然是与数据库相关的。但是如果是做工程型项目,基本不存在移植问题。
  重新编译问题,因为后端代码是运行前编译的,如果带有引用关系的对象发生改变时,受影响的存储过程、包将需要重新编译(不过也可以设置成运行时刻自动编译)。
  如果在一个程序系统中大量的使用存储过程,到程序交付使用的时候随着用户需求的增加会导致数据结构的变化,接着就是系统的相关问题了,最后如果用户想维护该系统可以说是很难很难、而且代价是空前的,维护起来更麻烦。

4. 存储过程举例(删除给定球员参加的所有比赛)

  mysql> delimiter $$  #将语句的结束符号从分号;临时改为两个$$(可以是自定义)

  mysql> CREATE PROCEDURE delete_matches(IN p_playerno INTEGER)

  -> BEGIN

  ->DELETE FROM MATCHES

  -> WHERE playerno = p_playerno;

  -> END$$

  Query OK, 0 rows affected (0.01 sec)

  mysql> delimiter;  #将语句的结束符号恢复为分号

5. 调用存储过程: call delete_matches(57);

  该执行语句会删除数据表MATCHES中playno为57的球员的记录。

6.  drop procedure delete_matches:  删除存储过程 (ps: 不能在一个存储过程中删除另一个存储过程,只能调用 另一个存储过程);

     show procedure status: 显示数据库中所有存储的存储过程基本信息,包括所属数据库,存储过程名称,创建时间等;

     show create procedure delete_matches: 显示某个mysql存储过程的详细信息

原文地址:https://www.cnblogs.com/simpleyou/p/11630349.html