zoukankan      html  css  js  c++  java
  • oracle 存储过程(1)

    说明

    创建一个存储过程与编写一个普通的PL/SQL程序快有很多相似地方,比如:包括生命部分,执行部分和异常部分.但是两者之间实现细节还是有很多差别的,比如:创建存储过程需要使用procedure关键字,在关键字后就是过程名称和参数列表;创建存储过程不需要使用declare关键字,而是使用create或replace.

    要创建一个过程对象(procedural object),必须有 CREATE PROCEDURE 系统权限。如果这个过程对象需要被其他的用户schema 使用,那么你必须有 CREATE ANY PROCEDURE 权限。执行 procedure 的时候,可能需要excute权限。或者EXCUTE ANY PROCEDURE 权限。如果单独赋予权限,如下例所示:  

    grant  execute on MY_PROCEDURE  to Jelly

    基本语法如下:

        CREATE [OR REPLACE] PROCEDURE 存储过程名[(参数[IN|OUT|IN OUT] 数据类型...)]
      {AS|IS}
      [说明部分]
      BEGIN   
      可执行部分
      [EXCEPTION
      错误处理部分]
      END [过程名];

    其中: 可选关键字OR REPLACE 表示如果存储过程已经存在,则用新的存储过程覆盖,通常用于存储过程的重建。 参数部分用于定义多个参数(如果没有参数,就可以省略)。参数有三种形式:IN、OUT和IN OUT。如果没有指明参数的形式,则默认为IN。 关键字AS也可以写成IS,后跟过程的说明部分,可以在此定义过程的局部变量。 编写存储过程可以使用任何文本编辑器或直接在SQL*Plus环境下进行,编写好的存储过程必须要在SQL*Plus环境下进行编译,生成编译代码,原代码和编译代码在编译过程中都会被存入数据库。编译成功的存储过程就可以在Oracle环境下进行调用了。 一个存储过程在不需要时可以删除。删除存储过程的人是过程的创建者或者拥有DROP ANY PROCEDURE系统权限的人。删除存储过程的语法如下:

    DROP PROCEDURE 存储过程名;

    存储过程的优点

    • 执行效率很高,因为存储过程是预编译的,即创建时编译,而SQL语句是执行一次,编译一次。调用存储过程可以大大减少同数据库的交互次数。
    • 降低网络通信量,因为存储过程执行的时候,只需要call存储过程名,不需要传递大量的SQL语句。 
    • 有利于复用。

    存储过程的缺点

    • 移植性非常差,如果在oracle上写的存储过程,移植到mysql需要修改。
    • 代码可读性差,实现一个简单的逻辑,代码会非常长。

    存储过程的用途

    • 造测试数据:可以使用存储过程,往表里造几百万条数据。
    • 数据同步:两个表之间按照一定的业务逻辑进行数据同步。
    • 数据挖掘。

    存储过程注意事项

    • 数据量大的时候(10万+),一定要做压力测试,有些存储过程在大数据量的情况下才会出现问题。
    • 如果插入或者更新的次数比较多,为了提高效率,可以执行一万次,再commit一次。
    • 如果先插入记录,没有commit,再对这条记录进行更新,会引起死锁。如果先后对同一笔记录进行更新,又没有commit,也会引起死锁。因为后一条语句会等待前一条语句提交。如果出现这种情况,则需要一条条commit。
    • 不要忘记在存储过程里写commit。

    性能测试

    •  用存储过程插入40万数据用了10秒。
    •  遍历并判断40万条数据用了25秒。
    •  80万次SQL判断+40万次SQL插入=25秒。

    扩展

    •  存储过程执行非常慢,有可能是更新语句引起了死锁,也有可能是语句执行慢(需要建索引)。
    •  存储过程编译非常慢,有可能是当前存储过程正在执行,被锁住了。(使用DBA帐号解锁)。

    实例:

    (1)  创建表

     create table dept(id int,name varchar(30),address varchar(20));

    (2) 创建存储过程

        create or replace procedure pro_insertDept is
     begin
     insert into dept values(100,'shimang','beijing');
     commit;
     dbms_output.put_line('insert sucess!');
     end pro_insertDept;

    (3) 执行存储过程

    SQL> execute pro_insertDept;

    PL/SQL 过程已成功完成。

    SQL> select * from dept;

            ID NAME ---------- ------------------------------------------------------------ ADDRESS ----------------------------------------      

          100 shimang beijing

  • 相关阅读:
    解决Firefox下outerHTML不支持问题
    神奇的css属性pointerevents
    IE6 double marginleft Bug
    解决IE低版本不支持call和apply问题
    JavaScript函数参数的可修改性
    IE6/7 double paddingbottom Bug
    各浏览器对document.getElementById等方法的实现差异
    JavaScript中两种类型的全局对象/函数
    JavaScript子类用Object.getPrototypeOf去调用父类方法
    JavaScript声明全局变量三种方式的异同
  • 原文地址:https://www.cnblogs.com/northeastTycoon/p/5596057.html
Copyright © 2011-2022 走看看