`
心杀心
  • 浏览: 31601 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

oracle存储过程使用

阅读更多

之前项目写了一段时间存储过程,抽点时间做个简单的总结,与大家共享。

数据库使用:

--Oracle存储过程创建语法:

--创建存储过程 create or replace procedure 存储过程名(param1 in type,param2 out type)

create or replace procedure test_proc(v_type in varchar2)

as

--常用变量,格式-变量 类型(值范围);

v_tsql        varchar2(2000); 

v_test_name  varchar2(50); 

v_id varchar2(50); 

v_rule varchar2(50); 


--游标声明及赋值 cursor 游标名(参数名 参数类型) is sql查询语句,条件可以包含参数,注:表名不可用参数代替,识别不出来。

CURSOR get_test_info(v_test_name varchar2) is

  select t.id,t.rule from testA t where t.status = 1 and t.test_name = v_test_name;

--开始存储过程

Begin

--执行游标,获取符合sql条件的数据列for 对象 in 游标名 loop

for job_row in get_test_info(v_type) loop

--开始循环

begin

--判断对象中属性rule(为游标sql查询列)不为空

if job_row.rule is not null then

--删除sql赋值

v_tsql:='delete from testA where id ='''||job_row.id||''' and trunc(d_day) = trunc(sysdate)';

--执行

         execute immediate v_tsql;

        --提交

         commit;

         --插入sql赋值,出现变量值:1,:2,为插入变量值,类似java执行sql语句中'?'

          v_tsql:= 'insert into testA (name) select name from testB where id = :1 ';

         --执行,using 变量值,顺序对应v_tsql中的:1,:2

          execute immediate v_tsql using job_row.id;

          commit;

          --输出sql,可以查看内容

          dbms_output.put_line(v_tsql);

       end if;

      EXCEPTION

         When others then

            begin

               dbms_output.put_line(SQLERRM);

             end ;

       end;

    end loop;

   

下面为存储过程其他循环方式,与上面for...loop等同 

   --游标循环 while写法

    --打开游标

    open get_test_info(v_type);

    fetch get_test_info into v_id,v_rule;

    while get_test_info%FOUND loop

    if job_row.rule is not null then

--删除sql赋值

v_tsql:='delete from testA where id ='''||job_row.id||''' and trunc(d_day) = trunc(sysdate)';

--执行

        execute immediate v_tsql;

       --提交

        commit;

        --插入sql赋值,出现变量值:1,:2,为插入变量值,类似java执行sql语句中'?'

         v_tsql:= 'insert into testA (name) select name from testB where id = :1 ';

        --执行,using 变量值,顺序对应v_tsql中的:1,:2

         execute immediate v_tsql using job_row.id;

         commit;

         --输出sql,可以查看内容

         dbms_output.put_line(v_tsql);

      end if;

      fetch get_test_info into v_id,v_rule;

       end loop;

  close  get_test_info;

 

  --游标循环 Loop写法

    --打开游标

    open get_test_info(v_type);

    loop

    fetch get_test_info into v_id,v_rule;

    EXIT WHEN get_test_info%NOTFOUND;

    if v_id is not null then

--删除sql赋值

v_tsql:='delete from testA where id ='''||v_id||''' and trunc(d_day) = trunc(sysdate)';

--执行

        execute immediate v_tsql;

       --提交

        commit;

        --插入sql赋值,出现变量值:1,:2,为插入变量值,类似java执行sql语句中'?'

         v_tsql:= 'insert into testA (name) select name from testB where id = :1 ';

        --执行,using 变量值,顺序对应v_tsql中的:1,:2

         execute immediate v_tsql using v_id;

         commit;

         exit;

         --输出sql,可以查看内容

         dbms_output.put_line(v_tsql);

      end if;

     end loop;

  close  get_test_info;

java调用:

String procedure = "{call test_proc(?) }";

//取得数据库连接

CallableStatement call = aaa.getConnection().prepareCall(procedure);

call.setString(1, opertype);

// 执行

call.execute();

分享到:
评论

相关推荐

    oracle存储过程使用文档

    ### Oracle存储过程使用知识点 #### 一、存储过程概述 - **定义**:存储过程(Stored Procedure)是在数据库中预编译的一组SQL语句集合,它可以被当作一个单独的对象来调用,只需要指定存储过程的名字及参数(如果...

    oracle存储过程使用游标对多表操作例子

    标题:“oracle存储过程使用游标对多表操作例子”直接指出了文章的主题是关于在Oracle环境下,如何利用存储过程和游标实现跨多个表的数据处理。描述部分重复了标题内容,强调了示例性质,表明文章将通过具体实例来...

    Oracle存储过程中使用临时表

    本篇文章将深入探讨如何在Oracle存储过程中使用临时表,包括会话级临时表和事务级临时表。 ### 会话级临时表 会话级临时表(Session-Level Temporary Tables)只在创建它的会话内可见,并且在会话结束时自动删除。...

    oracle存储过程使用详解

    ### Oracle存储过程使用详解 在Oracle数据库环境中,存储过程是一种重要的数据库对象,它允许开发者将一组SQL语句和控制流程语句封装在一个命名单元中,从而实现更复杂、更高效的数据处理逻辑。本文将深入探讨...

    超详细Oracle存储过程使用手册,只收1分

    这个“超详细Oracle存储过程使用手册”旨在为用户提供全面、深入的理解和实践指导。 一、存储过程的基础概念 存储过程是由一个或多个SQL和PL/SQL语句组成的程序单元,存储在数据库中并可以被调用执行。它们提高了...

    oracle存储过程学习经典入门

    用 Java 调用 Oracle 存储过程时,需要使用 JDBC 驱动程序来连接 Oracle 数据库,然后使用 CallableStatement 对象来调用存储过程。 在存储过程中做简单动态查询 在存储过程中,做简单动态查询需要使用 EXECUTE ...

    【精华志】超详细Oracle存储过程使用手册

    本手册“【精华志】超详细Oracle存储过程使用手册”深入探讨了这一主题,旨在帮助C#、ASP.NET开发者以及SQL和DBA专家更好地理解和应用存储过程。 1. **存储过程的概念与优势** - 存储过程是预编译的SQL和PL/SQL...

    oracle 存储过程 使用游标 判断2表 新增更新操作

    oracle存储过程使用游标判断2表差异,进行新增更新操作

    C#调用oracle方法(包括调用存储过程)

    本文将详细介绍如何使用C#语言连接Oracle数据库,并演示如何调用Oracle存储过程,特别是带有输出参数的情况。这些知识点对于初学者来说尤为重要。 #### 前置知识 1. **C#基础**:理解C#的基本语法和概念。 2. **...

    oracle 存储过程使用 sequence

    总结来说,Oracle存储过程结合Sequence的使用,能够有效地处理数据的插入和更新操作,特别是在需要唯一标识的情况下。在设计和实现时,我们需要考虑并发控制、性能优化以及业务需求的灵活性,以确保Sequence的正确性...

    ORACLE存储过程学习

    Oracle存储过程使用PL/SQL(Procedural Language for SQL)编写,这是一种专门为Oracle设计的过程化语言。 #### 二、存储过程的基本组成部分 存储过程包含以下几个主要部分: - **数据类型**:定义变量、常量和游标...

    oracle 存储过程导出excel

    oracle 存储过程导出excel oracle 存储过程导出excel oracle 存储过程导出excel oracle 存储过程导出excel oracle 存储过程导出excel

    oracle存储过程解锁

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

    oracle存储过程unwrap解密工具.zip

    Oracle存储过程unwrap解密工具主要用于处理Oracle数据库中的加密存储过程。在Oracle数据库系统中,为了保护敏感代码或数据,开发人员有时会选择对存储过程进行加密。然而,当需要查看、调试或恢复这些加密的存储过程...

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

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

    帆软报表Oracle存储过程解决storeParameter1参数试用插件

    此外,对于Oracle存储过程,理解其基本概念和使用方法也是必要的。存储过程是预编译的SQL语句集合,可以封装复杂的业务逻辑,提高数据处理效率,并通过参数传递数据。在与帆软报表集成时,正确理解和调用存储过程能...

    oracle 存储过程 函数 dblink

    在这段Java代码中,我们使用了`CallableStatement`来调用Oracle存储过程`TESTA`。关键点包括: - `prepareCall`方法用于准备调用存储过程。 - 使用`setString`方法设置输入参数的值。 - 调用`execute`方法执行存储...

    oracle存储过程-帮助文档

    Oracle存储过程是数据库管理系统中的一种重要特性,它允许开发者编写一系列SQL语句和PL/SQL块,形成可重复使用的代码单元。这篇博客“oracle存储过程-帮助文档”可能提供了关于如何创建、调用和管理Oracle存储过程...

    SQLServer存储过程转为oracle存储过程的工具

    可以将SQL Server存储过程转为oracle存储过程的工具

    使用java实现oracle存储过程

    使用java实现oracle存储过程。 共有3个小例子。实现的功能 1、无返回值的存储过程 如 insert 2、有返回值的存储过程(非列表)select id from tab 3、返回列表 如:select * from tab 顺便鄙视下csdn,作为一个it...

Global site tag (gtag.js) - Google Analytics