Oracle存储过程,游标使用
Oracle存储过程:
语法:
CREATE [OR REPLACE] PROCEDURE procedure_name
(arg1 [mode1] datatype1,arg2 [mode2] datatype2,...)
IS [AS]
PL/SQL BLOCK;
mode用于指定输入输出参数:IN为输入参数,OUT为输出参数,当为输入参数时可以省去IN,OUT不能省去。
如果没有输入输出参数,可以省去
(arg1 [mode1] datatype1,arg2 [mode2] datatype2,...)这一行
一个带有输入,输出参数的简单的例子
CREATE OR REPLACE PROCEDURE proc_in_out_test(var_empno NUMBER,
var_ename OUT VARCHAR2) IS
BEGIN
SELECT ename INTO var_ename FROM emp WHERE empno = var_empno;
EXCEPTION
WHEN no_data_found THEN
raise_application_error(-20000, '该员工不存在');
END;
调用该过程
SQL> var vempno number;
SQL> var vename varchar2(10);
SQL> exec :vempno:=7934;
SQL> exec proc_in_out_test(:vempno,:vename);
PL/SQL procedure successfully completed
vename
---------
MILLER SQL> exec :vempno:=7935;
SQL> exec proc_in_out_test(:vempno,:vename); begin proc_in_out_test(:vempno,:vename); end; ORA-20000: 该员工不存在
ORA-06512: 在 "SCOTT.PROC_IN_OUT_TEST", line 7
ORA-06512: 在 line 1
显示游标语法:
CURSOR cursor_name IS select_statement
一个简单的例子:
DECLARE
v_empname emp.ename%TYPE;
v_job emp.job%TYPE;
v_deptno emp.deptno%TYPE;
CURSOR emp_test IS --声明游标
SELECT ename, job FROM emp WHERE deptno = v_deptno;
BEGIN
v_deptno := 10;
OPEN emp_test; --打开游标
--循环游标
LOOP
FETCH emp_test
INTO v_empname, v_job; --取值
EXIT WHEN emp_test%NOTFOUND; --当没有记录时退出循环
dbms_output.put_line('empname=' || v_empname || ',job=' || v_job);
END LOOP;
CLOSE emp_test;
END;
--游标的属性有:%FOUND,%NOTFOUNRD,%ISOPEN,%ROWCOUNT;
--%FOUND:已检索到记录时,返回true
--%NOTFOUNRD:检索不到记录时,返回true
--%ISOPEN:游标已打开时返回true
--%ROWCOUNT:代表检索的记录数,从1开始
参数化游标只是声明方式和打开游标时有些不同
CURSOR emp_test2(p_deptno emp.deptno%TYPE) IS --声明游标
SELECT ename, job FROM emp WHERE deptno = p_deptno;
OPEN emp_test2(10); --打开游标
游标变量:
定义游标变更类型
TYPE type_name IS REF CURSOR[RETURN return_type];
CREATE OR REPLACE PROCEDURE cursorvariabletest(p_table IN VARCHAR2) IS
TYPE t_emp_dept IS REF CURSOR; --定义游标变量类型
v_cursorvar t_emp_dept; --声明游标变量 v_empno emp.empno%TYPE;
v_ename emp.ename%TYPE;
v_job emp.job%TYPE;
v_dname dept.dname%TYPE;
v_loc dept.loc%TYPE; BEGIN
IF p_table = 'emp' THEN
v_empno := 7369;
OPEN v_cursorvar FOR
SELECT ename, job FROM emp WHERE empno = v_empno; --打开游标变量
ELSE
IF p_table = 'dept' THEN
OPEN v_cursorvar FOR
SELECT dname, loc FROM dept; --打开游标变量
ELSE
raise_application_error(-20000, '请输入emp或dept!');
END IF;
END IF; LOOP
IF p_table = 'emp' THEN
FETCH v_cursorvar
INTO v_ename, v_job;
EXIT WHEN v_cursorvar%NOTFOUND;
dbms_output.put_line('ename=' || v_ename || ',job=' || v_job);
ELSE
FETCH v_cursorvar
INTO v_dname, v_loc;
EXIT WHEN v_cursorvar%NOTFOUND;
dbms_output.put_line('dname=' || v_dname || ',loc=' || v_loc);
END IF;
END LOOP;
CLOSE v_cursorvar; --关闭游标变量
END;
使用for循环
declare
cursor emp_cursor is select ename,sal from emp ;
begin
for emp_record in emp_cursor loop
dbms_output.put_line('姓名: '||emp_record.ename||' , 工资: '||emp_record.sal);
end loop;
end ;
/
约束与无约束的游标变量
无约束的游标变量包含特定的返回类型(type,rowtype,record等),查询的选择列表必须匹配游标的返回类型,否则会出现预
定义的ROWTYPE_MISMATCH异常。约束的游标变量没有Return子句。
Oracle存储过程,游标使用的更多相关文章
- Oracle存储过程游标for循环怎么写
一.不带参数的游标for循环 首先编写存储过程的整体结构,如下: create or replace procedure test_proc is v_date date; --变量定义 begin ...
- oracle存储过程+游标处理select数据
create or replace PROCEDURE UPDATE_RECORDCODE is cursor location_data is select * from location wher ...
- (转)oracle 存储过程 带游标作为OUT参数输出
(转)oracle 存储过程 带游标作为OUT参数输出 存储过程返回OUT参数的游标 例子. 包中带过程 要自己定义一个type [cur_name] is ref cursor游标,返回的时候就直接 ...
- C#执行oracle返回游标类型的存储过程
存储过程代码为: create or replace procedure proc_test(pCursor OUT pak_pub.ut_cursor) AS begin -- 使用游标 open ...
- Java调用oracle存储过程通过游标返回临时表数据
注:本文来源于 < Java调用oracle存储过程通过游标返回临时表数据 > Java调用oracle存储过程通过游标返回临时表数据 项目开发过程中,不可避免的会用到存储过程返回结 ...
- oracle存储过程(返回列表的存储结合游标使用)总结 以及在java中的调用
这段时间开始学习写存储过程,主要原因还是因为工作需要吧,本来以为很简单的,但几经挫折,豪气消磨殆尽,但总算搞通了,为了避免后来者少走弯路,特记述与此,同时亦对自己进行鼓励. 以下是我在开发项目中第一次 ...
- oracle存储过程和游标的使用
oracle存储过程和游标的使用 (2011-04-19 14:52:47) 转载▼ 游标: 用来查询数据库,获取记录集合(结果集)的指针,我们所说的游标通常是指显式游标,因此从现在起没有特别指明的情 ...
- ORACLE存储过程,循环语法和游标
1.定义所谓存储过程(Stored Procedure),就是一组用于完成特定数据库功能的SQL语句集,该SQL语句集经过编译后存储在数据库系统中.在使用时候,用户通过指定已经定义的存储过程名字并给出 ...
- oracle 存储过程
来自:http://www.jb51.net/article/31805.htm Oracle存储过程基本语法 存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 I ...
随机推荐
- 消息对话框 MessageBoxButtons
消息对话框MessageBox经常用于向用户显示通知信息.例如,在操作过程中遇到错误或程序异常,经常会使用这种方式给用户以提示,它是特殊类型的对话框. 在C#中,MessageBox消息对话框位于Sy ...
- laravel表单操作
$request->all()//获取所有参数if($request->isMethod('GET')){判断是否是GET请求}$res = $request->is('studen ...
- __str__ 和 __repr
#1 默认类里面默认提供的__str__方法,是返回类的内存地址class foo: def __init__(self): pass #2 修改类里面默认提供的__str__方法class fun: ...
- Java 8 方法引用
转自:https://www.runoob.com/java/java8-method-references.html 方法引用通过方法的名字来指向一个方法. 方法引用可以使语言的构造更紧凑简洁,减少 ...
- ES6语法的数组查询
setProductId(param){ console.log(param); let prod = this.products.find(item =>{ return item.prodC ...
- mvn多环境下的配置
在应用中,我们经常会遇到本地,测试和生产3种不同的环境,因此需要去配置不同的application. 定义resources: <resources> <resource> & ...
- chrome视频播放加速
安装video speed controller, 下载源码https://github.com/igrigorik/videospeed,解压 在chrome输入chrome://extention ...
- TCP与UDP,可靠UDP如何实现
两种协议都是传输层协议,为应用层提供信息载体. TCP协议是基于连接的字节流的可靠协议,有三次握手,四次挥手,超时重传,流量控制(滑动窗口),拥塞控制和差错控制,也正因为有可靠性的保证和控制手段,所以 ...
- push() 方法将一个或多个元素添加到数组的末尾,并返回新数组的长度
var numbers = [1, 2, 3]; numbers.push(4); console.log(numbers); // [1, 2, 3, 4] numbers.push(5, 6, 7 ...
- 37.Spring-事务控制.md
目录 1.分类 2.Spring对jadc事务管理 2.1xml方式 2.1.1首先定义Dao对象和Server对象 2.1.2配置文件实现事务管理 2.2注解方式 2.2.1对象类 2.2.2配置文 ...