`

Oracle 存储过程示例

阅读更多
Oracle 存储过程示例

1. SQLPLUS 之 SET 命令:

SQL>set colsep' ';     //-域输出分隔符

SQL>set echo off;     //显示start启动的脚本中的每个sql命令,缺省为on

SQL> set echo on               //设置运行命令是是否显示语句

SQL> set feedback on;       //设置显示“已选择XX行”

SQL>set feedback off;      //回显本次sql命令处理的记录条数,缺省为on

SQL>set heading off;     //输出域标题,缺省为on

SQL>set pagesize 0;      //输出每页行数,缺省为24,为了避免分页,可设定为0。

SQL>set linesize 80;      //输出一行字符个数,缺省为80

SQL>set numwidth 12;     //输出number类型域长度,缺省为10

SQL>set termout off;     //显示脚本中的命令的执行结果,缺省为on

SQL>set trimout on;   //去除标准输出每行的拖尾空格,缺省为off

SQL>set trimspool on;  //去除重定向(spool)输出每行的拖尾空格,缺省为off

SQL>set serveroutput on;  //设置允许显示输出类似dbms_output

SQL> set timing on;          //设置显示“已用时间:XXXX”

SQL> set autotrace on-;    //设置允许对执行的sql进行分析

set verify off                     //可以关闭和打开提示确认信息old 1和new 1的显示.


2. 过程

-- 表t5管理过程

-- BEGIN 存储过程
create or replace procedure tablemanage(optype in integer, pk in integer) as
       -- 变量声明
       v_optype integer := optype; -- 0 查询 1 删除
       v_entity t5%ROWTYPE; -- 实体
       
       v_pk integer := NVL(pk, '');
       
       v_code NUMBER;
       v_errm VARCHAR2(64);
       
       CURSOR v_cursor IS
              SELECT * FROM t5;
begin
       -- 过程体
       DBMS_OUTPUT.put_line('start table t5 process... ');
       
           -- 查询
           if v_optype = 0 then
               -- 打开游标
               OPEN v_cursor;
               
               -- 提取数据
               LOOP
                   fetch v_cursor into v_entity;
                         DBMS_OUTPUT.put_line('query...' || v_entity.id);
                         
                   EXIT when v_cursor%NOTFOUND;
               END LOOP;
               
               -- 关闭游标
               CLOSE v_cursor; 
               
            -- 删除   
            elsif v_optype = 1 then
               delete from t5 where id = v_pk;
               commit;
            elsif v_optype = 2 then
               insert into t5 values (3, 'wang5');
               commit;
            elsif v_optype = 3 then
               update t5 set name = 'ma6' where id = v_pk;
               commit;
            end if;
            
        
        DBMS_OUTPUT.put_line('start table t5 process...ok.');
    
exception
         -- 异常处理
         when others then
              DBMS_OUTPUT.put_line('An exception occurred.');
              v_code := SQLCODE;
              v_errm := SUBSTR(SQLERRM, 1 , 64);
              DBMS_OUTPUT.PUT_LINE('Error code ' || v_code || ': ' || v_errm);
              rollback;
        
              
              -- 记录错误日志表
              DBMS_OUTPUT.put_line('start logging into error_log...');
              
              insert into error_log values (sysdate, v_entity.id, v_code, v_errm);
              commit;
              
             DBMS_OUTPUT.put_line('start logging error_log... ok.');

-- END 存储过程
end tablemanage;


3. 创建表
create table t5(id integer primary key , name varchar(20));
create table error_log(now date primary key, id varchar2(20), error_code number, error_msg varchar2(255));
insert into t5 values (1, 'zhang3');
insert into t5 values (2, 'li4');
commit;




4. SQLPLUS调用过程
SQL> set serveroutput on
SQL> select * from t5
  2  ;

        ID NAME
---------- ----------------------------------------
         2 li4
         3 ma6

SQL> call tablemanage(0, 0);
start table t5 process...
query...2
query...3
query...3
start table t5 process...ok.

调用完成。

SQL>


5. 完成
分享到:
评论

相关推荐

    oracle 存储过程示例

    oracle 存储过程示例oracle 存储过程示例oracle 存储过程示例oracle 存储过程示例oracle 存储过程示例oracle 存储过程示例oracle 存储过程示例oracle 存储过程示例

    oracle存储过程示例

    这是一个简单的oracle代码,可进行参考

    oracle的一个简单存储过程实例

    Oracle存储过程是数据库管理系统中的一种重要特性,它允许开发者编写包含一系列SQL语句和PL/SQL块的可重用代码段。在这个“Oracle的一个简单存储过程实例”中,我们可以看到如何在Oracle环境中创建、调用和管理存储...

    java调用oracle存储过程示例+分页示例

    ### Java调用Oracle存储过程与分页示例详解 #### 一、无返回值的存储过程调用 在Java中调用Oracle存储过程时,若该过程无返回值,主要利用`CallableStatement`对象来执行。以下是一个具体的示例: ##### 存储过程...

    oracle存储过程学习经典(实例)

    Oracle存储过程是数据库管理系统Oracle中的一个重要特性,它允许开发者编写一系列的SQL和PL/SQL语句,形成一个可重用的代码块。这个"Oracle存储过程学习经典(实例)"资源显然是为初学者设计的,旨在帮助他们掌握如何...

    Python使用cx_Oracle调用Oracle存储过程的方法示例

    本文实例讲述了Python使用cx_Oracle调用Oracle存储过程的方法。分享给大家供大家参考,具体如下: 这里主要测试在Python中通过cx_Oracle调用PL/SQL。 首先,在数据库端创建简单的存储过程。 create or replace ...

    oracle存储过程解锁

    以下是对“oracle存储过程解锁”这一主题的深入解析。 ### 标题:“oracle存储过程解锁” #### 解析: 在Oracle数据库中,存储过程是一种预先编译并存储在数据库中的SQL代码块,用于执行复杂的业务逻辑或数据处理...

    Oracle存储过程返回结果集

    在Oracle存储过程中,`IN`参数用于传递数据到过程,`OUT`参数则允许过程向调用者返回数据。而`SYS_REFCURSOR`是Oracle提供的一种特殊类型,它允许存储过程动态地打开一个游标(即结果集)并将其作为`OUT`参数返回。 ...

    oracle存储过程-帮助文档

    `oracle procedure.chm`是一个帮助文件,通常包含详细的参考信息、示例和教程,供用户学习和查询Oracle存储过程的用法。CHM(Compiled HTML Help)格式是一种微软提供的离线帮助文档格式,用户可以通过搜索和导航来...

    hibernate query调用oracle存储过程

    以下是一个简单的示例,展示了如何调用一个不带参数的Oracle存储过程: ```java Session session = sessionFactory.openSession(); Transaction transaction = session.beginTransaction(); session....

    oracle 存储过程 函数 dblink

    ### Oracle存储过程、函数与DBLink详解 #### 一、Oracle存储过程简介 在Oracle数据库中,存储过程是一种预编译好的SQL代码集合,它可以接受输入参数、返回单个值或多个值,并能够执行复杂的数据库操作。存储过程...

    Oracle存储过程基本语法及示例

    ### Oracle存储过程基本语法及示例 在Oracle数据库中,存储过程是一种强大的工具,用于封装一组SQL语句或PL/SQL代码块,以便在数据库服务器上执行特定的任务。存储过程可以提高应用程序性能、确保数据完整性并简化...

    ORACLE存储过程最全教程

    Oracle存储过程是数据库管理系统Oracle中的一个关键特性,它允许开发者编写一组预编译的SQL和PL/SQL语句,以实现特定的...教程中的20篇文档将覆盖这些知识点的详细解释和示例,帮助你逐步成为Oracle存储过程的专家。

    用callabledStatement调用oracle存储过程实用例子(IN OUT 传游标)

    本示例展示了如何使用 CallabledStatement 来调用 Oracle 存储过程,并实现 IN OUT 参数和游标类型参数的使用。这种方法可以提高应用程序的性能和安全性。同时,游标类型参数的使用可以实现数据的批量处理,提高应用...

    oracle 存储过程批量提交

    ### Oracle存储过程批量提交知识点详解 在Oracle数据库中,存储过程是一种重要的数据库对象,它可以包含一系列SQL语句和控制流语句,用于实现复杂的业务逻辑处理。存储过程不仅可以提高应用程序性能,还可以确保...

    最权威的Orcale存储过程示例

    在提供的压缩包"Oracle存储过程"中,你可能会找到各种类型的存储过程示例,涵盖不同的业务需求和技术实现。通过分析和实践这些示例,你将加深对Oracle存储过程的理解,提高数据库开发能力。记得结合实际场景进行练习...

    oracle存储过程写法

    根据提供的Oracle存储过程示例,我们可以详细解析其中的关键知识点,包括存储过程的创建、游标的使用、临时表的创建及数据处理等。 ### 存储过程的创建与使用 存储过程是在数据库中编写的SQL代码块,它可以接受...

    oracle 事务 回滚 存储过程

    ### Oracle存储过程 存储过程是在数据库中预编译的一组SQL语句,用于执行复杂的业务逻辑或数据操作。它们可以接受输入参数,执行一系列数据库操作,并返回结果。在Oracle中,存储过程使用PL/SQL编写,可以在数据库...

    润乾报表调用oracle存储过程案例说明

    在实际的业务场景中,有时我们需要调用数据库中的存储过程来获取或处理数据,本篇将详细介绍如何在润乾报表中调用Oracle存储过程。 首先,我们要在Oracle数据库中创建存储过程。以下是一个简单的存储过程示例,名为...

Global site tag (gtag.js) - Google Analytics