一,oracle存储过程语法
 
 
 
1.oracle存储过程结构
 
CREATE OR REPLACE PROCEDURE oracle存储过程名字
 
(
 
    参数1 IN NUMBER,
 
    参数2 IN NUMBER
 
) IS
 
变量1 INTEGER :=0;
 
变量2 DATE;
 
BEGIN
 
END oracle存储过程名字
 
 
 
2.无返回值的oracle存储过程
 
create or replace procedure xs_proc_no is
 
begin
 
  insert into xuesheng values (3, 'wangwu', 90, 90);
 
  commit;
 
end xs_proc_no;
 
 
 
3.有单个数据值返回的oracle存储过程
 
create or replace procedure xs_proc(temp_name in varchar2,
 
                                    temp_num  out number) is
 
  num_1 number;
 
  num_2 number;
 
begin
 
  select yu_wen, shu_xue
 
    into num_1, num_2
 
    from xuesheng
 
   where xing_ming = temp_name;
 
  --dbms_output.put_line(num_1 + num_2);
 
  temp_num := num_1 + num_2;
 
end;
 
其中,以上两种与sql server基本类似,而对于返回数据集时,上述方法则不能满足我们的要求。在Oracle中,一般使用ref cursor来返回数据集。示例代码如下:
 
 
 
4.有返回值的oracle存储过程(列表返回)
 
首先,建立我们自己的包。并定义包中的一个自定义ref cursor
 
create or replace package mypackage as
 
  type my_cursor is ref cursor;
 
end mypackage;
 
在定义了ref cursor后,可以书写我们的程序代码
 
create or replace procedure xs_proc_list(shuxue   in number,
 
                                         p_cursor out mypackage.my_cursor) is
 
begin
 
  open p_cursor for
 
    select * from xuesheng where shu_xue > shuxue;
 
end xs_proc_list;
 
 
 
5.SELECT INTO STATEMENT
 
  将select查询的结果存入到变量中,可以同时将多个列存储多个变量中,必须有一条
 
  记录,否则抛出异常(若没有记录则抛出NO_DATA_FOUND)
 
  例子:
 
  BEGIN
 
  SELECT name,age into 变量1,变量2 FROM user where xxx;
 
  EXCEPTION
 
  WHEN NO_DATA_FOUND THEN
 
      xxxx;
 
  END;
 
  ...
 
 
 
6.IF 判断
 
  IF V_TEST=1 THEN
 
    BEGIN
 
       do something
 
    END;
 
  END IF;
 
 
 
7.WHILE 循环
 
  WHILE V_TEST=1 LOOP
 
  BEGIN
 
 XXXX
 
  END;
 
  END LOOP;
 
 
 
8.变量赋值
 
  V_TEST := 123;
 
 
 
9.用FOR IN 使用cursor
 
  ...
 
  IS
 
  CURSOR cur IS SELECT * FROM xxx;
 
  BEGIN
 
 FOR cur_result in cur LOOP
 
  BEGIN
 
   V_SUM :=cur_result.列名1+cur_result.列名2
 
  END;
 
 END LOOP;
 
  END;
 
 
 
10.带参数的CURSOR
 
  CURSOR C_USER(C_ID NUMBER) IS SELECT NAME FROM USER WHERE TYPEID=C_ID;
 
  OPEN C_USER(变量值);
 
  LOOP
 
 FETCH C_USER INTO V_NAME;
 
 EXIT FETCH C_USER%NOTFOUND;
 
    do something
 
  END LOOP;
 
  CLOSE C_USER;
 
 
 
11.用pl/sql developer debug
 
  连接数据库后建立一个Test WINDOW
 
  在窗口输入调用SP的代码,F9开始debug,CTRL+N单步调试
 
 
 
二,oracle存储过程的若干问题备忘
 
 
 
1.在oracle中,表别名不能加as,如:
 
select a.name from user a;-- 正确
 
select a.name from user as a;-- 错误

oracle存储过程 --1的更多相关文章

  1. oracle 存储过程

    来自:http://www.jb51.net/article/31805.htm Oracle存储过程基本语法 存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 I ...

  2. Oracle存储过程语法

    原文链接:http://www.jb51.net/article/31805.htm Oracle存储过程基本语法 存储过程  1 CREATE OR REPLACE PROCEDURE 存储过程名  ...

  3. ORACLE存储过程调用Web Service

    1. 概述 最近在ESB项目中,客户在各个系统之间的服务调用大多都是在oracle存储过程中进行的,本文就oracle存储过程调用web service来进行说明.其他主流数据库,比如mysql和sq ...

  4. Oracle存储过程基本语法介绍

    Oracle存储过程基本语法 存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 IS 3 BEGIN 4 NULL; 5 END; 行1: CREATE OR RE ...

  5. MyBatis调用Oracle存储过程

    MyBatis调用Oracle存储过程 1.无输入和输出参数的存储过程 2.带有输入和输出参数的存储过程 3.返回游标的存储过程 mybatis中的配置文件代码 <resultMap type= ...

  6. Oracle存储过程(转)

    Oracle存储过程基本语法 存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 IS 3 BEGIN 4 NULL; 5 END; 行1: CREATE OR RE ...

  7. Oracle存储过程中异常Exception的捕捉和处理

    Oracle存储过程中异常的捕捉和处理 CREATE OR REPLACE Procedure Proc_error_process ( v_IN in Varchar2, v_OUT Out Var ...

  8. Oracle存储过程动态创建临时表/存储过程执行权限问题--AUTHID CURRENT_USER

    关于Oracle存储过程执行权限问题的解决 http://blog.sina.com.cn/s/blog_6ceed3280101hvlo.html (2014-04-02 04:06:28) 转载▼ ...

  9. ORACLE存储过程学习

    存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 IS 3 BEGIN 4 NULL; 5 END; 行1: CREATE OR REPLACE PROCEDURE ...

  10. C# 获取 oracle 存储过程的 返回值1

    /// <summary> /// 返回对应表的模拟自增字段值 /// </summary> /// <param name="tablename"& ...

随机推荐

  1. linux device driver —— 环形缓冲区的实现

    还是没有接触到怎么控制硬件,但是在书里看到了一个挺巧妙的环形缓冲区实现. 此环形缓冲区实际为一个大小为bufsize的一维数组,有一个rp的读指针,一个wp的写指针. 在数据满时写进程会等待读进程读取 ...

  2. urlconnection用法(转)

    1.获取ip地址 package demo.net; import java.net.InetAddress; import java.net.UnknownHostException; /* * 获 ...

  3. Java基础知识强化之集合框架笔记40:Set集合之HashSet存储自定义对象并遍历

    1. HashSet存储自定义对象并遍历 2. 代码示例: (1)Student类,如下: package cn.itcast_02; /** * @author Administrator * */ ...

  4. Bginfo软件在域的部署和应用

    在企业的IT管理中,很多用户都不知道怎么去查看自己计算机的IP地址.登陆帐户.而对于网络管理人员来说,他们可能需要知道用户在域中登录的一些信息,如那些用户登录过,在什么时间登录,IP和MAC地址是多少 ...

  5. Myeclipse快捷键的设置

  6. SQL语句优化(分享)

    一.操作符优化 1.IN 操作符 用IN写出来的SQL的优点是比较容易写及清晰易懂,这比较适合现代软件开发的风格.但是用IN的SQL性能总是比较低的,从Oracle执行的步骤来分析用IN的SQL与不用 ...

  7. OSI 网络七层模型(笔记)

    一直以来我们都在使用着互联网,每天聊着qq,上着淘宝,但是却不了解怎么运行的呢,充满了好奇.今天同过了解来总结一下OSI网络七层模型: 上一张图 OSI (open system interconne ...

  8. What's the use of @ before the path defination

    When you define your path const : const string Child_Medical_Pdf = @"~/Media/ChildPdf"; Th ...

  9. 总结Widows 7 Start->Run 命令

    Widows + R基本上成为很常用的方式,那么通过Windows + R我们可以在运行中做什么手脚呢. 下面从最基本的系统命令说起 notepad--------打开记事本    services. ...

  10. extern "C" {} 来沟通C和C++

    比如说你用C++开发了一个DLL库,为了能够让C语言也能够调用你的DLL输出(Export)的函数,你需要用extern "C"来强制编译器不要修改你的函数名. 通常,在C语言的头 ...