Oracle基础 存储过程和游标

一、带游标的存储过程

  游标作为参数有两种类型:

  1、声明系统游标类型 SYS_REFCURSOR

  1)游标作为存储过程的参数:

--带游标的存储过程
CREATE OR REPLACE PROCEDURE PRO_EMP_IN(EMP_CUR SYS_REFCURSOR) AS
  V_NAME EMP.ENAME%TYPE;
  V_SAL  EMP.SAL%TYPE;
BEGIN
  LOOP
    FETCH EMP_CUR
      INTO V_NAME, V_SAL;
    DBMS_OUTPUT.PUT_LINE(‘name:‘ || V_NAME || ‘   sal:‘ || V_SAL);
    EXIT WHEN EMP_CUR%NOTFOUND;
  END LOOP;
END;

  调用带游标的存储过程:

--调用带游标的存储过程
DECLARE
  EMP_CUR SYS_REFCURSOR;
BEGIN
  OPEN EMP_CUR FOR
    SELECT ENAME, SAL FROM EMP;
  PRO_EMP_IN(EMP_CUR => EMP_CUR);
  CLOSE EMP_CUR;
END; 

  

  2)带输出游标的存储过程

--SYS_REFCURSOR 带输出参数的系统游标类型
CREATE OR REPLACE PROCEDURE PRO_EMP(EMP_CUR OUT SYS_REFCURSOR) AS
BEGIN
  OPEN EMP_CUR FOR
    SELECT ENAME, SAL FROM EMP E;   --和查询语句绑定
END;

  调用带输出游标的存储过程:  

--调用带输出类型的游标的存储过程
DECLARE
  V_NAME  EMP.ENAME%TYPE;
  V_SAL   EMP.SAL%TYPE;
  EMP_CUR SYS_REFCURSOR;    --声明系统游标类型
BEGIN
  PRO_EMP(EMP_CUR => EMP_CUR);
  LOOP
    FETCH EMP_CUR INTO V_NAME, V_SAL;
    DBMS_OUTPUT.PUT_LINE(‘name:‘ || V_NAME || ‘   sal:‘ || V_SAL);
    EXIT WHEN EMP_CUR%NOTFOUND;
  END LOOP;
  CLOSE EMP_CUR;
END;

  2、声明自定义游标类型。

  

时间: 2024-08-29 16:30:02

Oracle基础 存储过程和游标的相关文章

Oracle基础 存储过程

一.子程序 子程序是已命名的PL/SQL块,它们存储在数据库中,可以Wie它们指定参数,可以从任何数据库客户端和应用程序中调用它们.子程序包括存储过程和函数. 子程序包括: 1.声明部分:声明部分包括类型.游标.常量.变量.异常和嵌套子程序的声明.这些项都是局部的,在退出后就不复存在. 2.可执行部分:可执行部分包括赋值.控制执行过程以及操纵ORacle数据的语句. 3.异常处理部分: 异常处理部分包括异常处理程序,负责处理执行存储过程中出现的异常. 子程序的有点: 1.模块化:通过子程序,可以

Oracle(三)存储过程与游标

1.程序包头 1 create or replace package pck_demo --声明一个程序包头,注意:包头与包体的名称一样 2 as -- 语法 3 4 type mycursoris ref cursor;-- 声明一个(引用)游标类型 5 -- 第一个存储过程,查询所有的角色(根据关键字),需要先执行一个存储过程完成后,在去添加新的存储过程 6 procedure get_all_role( 7 cname in varchar2,-- 输入参数 8 vresult out m

Oracle调用存储过程返回游标结果

/** 调用Oracle存储过程 */ public ResultSet queryForAllJSD_NEWEST(final String hpCode, final String id) { System.out.println("hpCode:"+hpCode+",id:"+id); ResultSet rs = (ResultSet)this.jdbctemplate.execute("{call pro_querybcb_newest(? ,

Oracle基础 存储过程和事务

一.事务和存储过程 在存储过程中如何使用事务.当需要在存储过程中同时执行多条添加.修改.删除SQL语句时,为了保证数据完整性,我们需要使用事务.使用方式和在PL-SQL中非常相似,但也有一些区别. --带事务的存储过程 CREATE OR REPLACE PROCEDURE Account_zhuanzhang(fromuser NUMBER,touser NUMBER,money NUMBER) IS BEGIN UPDATE account SET balance = balance - m

懵懂oracle之存储过程

/* 作为一个oracle界和厨师界的生手,笔者想给大家分享讨论下存储过程的知识,因为在我接触的通信行业中,存储过程的使用还是占据了一小块的地位. 存储过程是什么?不得不拿下百度词条的解释来:"存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中, 经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它.存储过程是数据库中的一个重要对象." 其实就似我们经过一系列的

对sqlserver存储过程合游标的一些理解

在最近老板给我的数据库操作要求中,有一张类似购物清单样式的表,表中有客户ID,商品ID,商品数量,单价和商品总价,出售日期.还有一张商品折扣信息表,在这基础上商品价格同一商品价格会有差异,不同客户最高折扣额不同,折扣率也有差异,要求用sqlserver存储过程合游标表诉 一开始根本没有思路和头绪,听老大讲解是要用存储过程将查询到的数据存储好,再用游标循环遍历.对于存储过程合游标的表诉一直不太熟,之前只是将用sql语句查到的结果集放到存储过程里面,对于游标的了解不够深入.所以一开始也是想着用sql

懵懂oracle之存储过程2

上篇<懵懂oracle之存储过程>已经给大家介绍了很多关于开发存储过程相关的基础知识,笔者尽最大的努力总结了所有接触到的关于存储过程的知识,分享给大家和大家一起学习进步.本篇文章既是完成上篇文章中未来得及总结的关于存储过程的调用.测试等知识的汇总分享,也是对上篇文章的存储过程的一个调试改错过程(由于知识的局限性和书写时的疏忽等,之前的存储过程有误之处难免,正在不断更改中,如果能得到大家的指正将使这个工作进行地更快更好,助人为快乐之本!). 下面步入正题,介绍本篇知识汇总和分享: 一.存储过程的

Oracle基础 数据库备份和恢复

原文:Oracle基础 数据库备份和恢复 一.为什么需要数据备份 造成数据丢失的主要原因: 1.介质故障. 2.用户的错误操作. 3.服务器的彻底崩溃. 4.计算机病毒. 5.不可预料的因素. Oracle中故障类型分为以下4种. 1.语句故障: 执行SQL语句过程发生的逻辑故障可导致语句故障.如果用户编写的SQL语句无效,就会发生语句故障.Oracle可自我修复语句故障,撤销语句产生的而印象,并将控制权交给应用程序. 2.用户进程故障 当用户程序出错而无法访问Oracle数据库时,就会发生用户

oracle的存储过程

用了两年Oracle还没写过存储过程,真是十分惭愧,从今天开始学习Oracle存储过程,完全零起点,争取每日一篇学习笔记,可能开始认识的不全面甚至有错误,但坚持下来一定会有收获. 1. 建立一个存储过程 create or replace PROCEDURE firstPro IS BEGIN DBMS_OUTPUT.PUT_LINE('Hello World!'); END; 其中IS关键字替换为AS关键字结果不会出现任何变化,大多认为他们是等同的,但也有一种说法解释为:一般PACKAGE 或