- 浏览: 90882 次
文章分类
最新评论
静态游标和REF游标,静态游标分为:显示游标/隐式游标
显示游标使用步骤:声明游标,打开,读取,关闭
declare cursor cursor_name
open cursor_name
fetch cursor_name into record_name
close cursor_name
对于fetch要执行多条语句操作时,添加loop/end loop;
使用fetch...into...是单条数据提取,
使用fetch...bulk collect into + for进行批量提取
declare
cursor my_test is select * from user_source;
type tab is table of user_source%rowtype;
row_record tab;
begin
open my_test;
loop
fetch my_test bulk collect into row_record ;
for i in 1..row_record.count
loop
dbms_output.put_line(row_record(i).type||'---'||row_record(i).name);
end loop;
exit when my_test%notfound;
end loop;
close my_test;
end;
或是用cursor for loop迭代
declare
cursor my_test is select name,type from user_source;
begin
for index1 in my_test
loop
dbms_output.put_line(index1.name||'---'||index1.type);
end loop;
end;
游标的属性
%isopen(true/false) if my_test%isopen then else
%found(true/false) if my_test%found then else
%notfound(true)
%rowcount(int) 当前游标的行数
带参数的游标 191/171
隐式游标SQL 192/172
显示游标使用步骤:声明游标,打开,读取,关闭
declare cursor cursor_name
open cursor_name
fetch cursor_name into record_name
close cursor_name
declare cursor my_test is select * from SF_OPERATORLOG; row_record SF_OPERATORLOG%rowtype; (声明类型,或者varchar(20),oid%type) begin open my_test; fetch my_test into row_record; dbms_output.put_line(row_record.oid||'%$%'||row_record.tablename); close my_test; end;
对于fetch要执行多条语句操作时,添加loop/end loop;
declare cursor my_test is select name,type from user_source; row_oid user_source.name%type; row_tablename user_source.type%type; begin open my_test; loop fetch my_test into row_oid,row_tablename; exit when my_test%notfound; dbms_output.put_line(row_oid||'%$%'||row_tablename); end loop; close my_test; end;
使用fetch...into...是单条数据提取,
使用fetch...bulk collect into + for进行批量提取
declare
cursor my_test is select * from user_source;
type tab is table of user_source%rowtype;
row_record tab;
begin
open my_test;
loop
fetch my_test bulk collect into row_record ;
for i in 1..row_record.count
loop
dbms_output.put_line(row_record(i).type||'---'||row_record(i).name);
end loop;
exit when my_test%notfound;
end loop;
close my_test;
end;
或是用cursor for loop迭代
declare
cursor my_test is select name,type from user_source;
begin
for index1 in my_test
loop
dbms_output.put_line(index1.name||'---'||index1.type);
end loop;
end;
游标的属性
%isopen(true/false) if my_test%isopen then else
%found(true/false) if my_test%found then else
%notfound(true)
%rowcount(int) 当前游标的行数
带参数的游标 191/171
隐式游标SQL 192/172
发表评论
-
###spring事务
2015-04-15 11:22 0Spring声明式事务让我们从复杂的事务处理中得到解脱 ... -
1、架构师之路
2015-03-11 13:56 0http://developer.51cto.com/deve ... -
精华帖
2015-03-11 11:10 403http://www.iteye.com/magazines/ ... -
2、mongodb运用
2015-03-10 11:46 491进入db:mongodb/ ./bin/mongo loca ... -
3、VMware虚拟机共享文件夹的使用
2015-03-10 09:40 8391、安装vmware tools 先启动一个linux系统 h ... -
1.nosql-MongoDB(linux安装)
2015-03-10 11:39 367NoSQL,泛指非关系型的数据库。随着互联网web2.0网 ... -
llll、activti-spring
2015-03-04 07:36 584这里使用的是5.12版本 将activiti-explorer ... -
5、juery 表单选择器
2015-03-03 21:52 475表单选择器 $('input').val(); //元素名定位 ... -
4、jquery对象选择器+对象值
2015-03-03 21:51 6851、封装js函数 2、浏览器兼容 3、css样式 4、增加脚本 ... -
3、javascript(3)
2015-03-03 21:51 535@@@@@@@@@@@@@@@@@@@ -
2、javascript(2)
2015-03-03 21:51 448对象和事件是JavaScript的两个核心。 JavaScr ... -
1、javascript(1)
2015-03-03 21:51 443link:http://wenku.baidu.com/vie ... -
2、操作系统
2015-03-04 19:45 462kernel是掌管一台pc硬件的程序,核心程序放置在内存当中且 ... -
1、计算机概论
2015-03-04 19:45 512计算机其实就是:『接受用户输入指令与数据, 经由中央处理器的数 ... -
7、多线程
2015-03-01 08:19 23在项目中使用多线程的场景并不是很多,我想是一般项目对线程 ...
相关推荐
在本篇讨论中,我们将深入理解Oracle游标、异常处理以及如何在存储过程中使用它们。 1. **Oracle游标**: - **定义**:Oracle游标是数据库系统提供的一种机制,用于在结果集中定位并处理单条记录。它实际上是一个...
通过学习这些案例,你可以了解如何在实际应用中灵活运用Oracle游标,包括在存储过程、触发器等高级功能中。案例中的7-游标使用很可能是对各种游标操作的具体示例,如打开、关闭、提取数据、循环处理等,有助于加深...
Oracle 数据库游标、存储过程和触发器 Oracle 数据库是一种关系型数据库管理系统,它提供了多种机制来提高数据库的性能和安全性。在本文中,我们将讨论 Oracle 数据库中的三个重要概念:游标、存储过程和触发器。 ...
在"游标.txt"文件中,可能包含了更多关于Oracle游标的使用实例和技巧,包括游标的声明、动态游标、游标变量、游标表达式以及游标在存储过程和函数中的应用。这些内容可以帮助你更深入地理解和掌握Oracle游标,提高你...
### Oracle存储过程、游标、函数的详解 #### 一、概述 在Oracle数据库中,存储过程、游标和函数是非常重要的组成部分,它们为数据库管理提供了强大的编程能力。通过学习这些概念,我们可以更加灵活地管理和操作...
Oracle游标是数据库管理系统中的一种数据处理机制,它允许用户按需逐行处理查询结果,而不是一次性加载所有数据。在Java编程中,我们通常通过JDBC(Java Database Connectivity)来与Oracle数据库交互,其中游标扮演...
### Oracle中的游标详解 #### 一、引言 在Oracle数据库中,游标是一种非常重要的机制,它允许用户在程序中对查询结果进行逐行处理。游标分为两种主要类型:**隐式游标**和**显示游标**。此外,还可以利用游标进行...
以下是关于Oracle游标使用的一些关键知识点: 1. **游标的基本概念**: 游标(Cursor)是一种机制,它允许我们遍历和操作由SQL查询返回的结果集。通过游标,我们可以控制数据的读取顺序,一次只处理一行,或者在...
1. 创建Oracle存储过程,包含一个或多个OUT参数,这些参数为游标。 2. 在Java中,使用`CallableStatement`调用存储过程,注册OUT参数为`OracleTypes.CURSOR`类型。 3. 执行存储过程并获取返回的游标对象。 4. 将游标...
Oracle游标是数据库编程中非常重要的一个概念,主要用于处理SQL查询的结果集。游标允许我们按需逐行处理数据,而不是一次性加载所有结果。这里详细介绍了Oracle中的三种游标类型:隐式游标、显式游标和REF游标。 1....
- 支持游标的游标(`cursor.callproc()`),用于调用存储过程。 - 支持绑定变量(`cursor.execute(query, params)`),提高执行效率。 - 可以处理 LOB(大型对象)数据类型,如 BFILE、BLOB、CLOB 和 NCLOB。 10...
本主题将深入探讨Oracle中的几个核心概念:函数、存储过程、游标以及简单的实例,这些都是数据库管理员和开发人员日常工作中不可或缺的部分。 首先,我们来了解**Oracle函数**。函数是预定义的代码块,接受零个或多...
在这个场景中,我们有三个文件:TESTPACKAGE.txt,CURSOR_TEST2.txt和OracleProcedure.java,分别涉及Oracle存储过程的创建、游标的使用以及Java代码如何与Oracle存储过程交互。 首先,`TESTPACKAGE.txt`很可能包含...
cx_Oracle还支持更高级的功能,如参数绑定、存储过程调用、事务控制、异常处理等。例如,你可以使用%s占位符来绑定变量,防止SQL注入攻击: ```python query = 'SELECT * FROM table_name WHERE column = %s' ...
Oracle游标,或称为光标,是数据库管理系统中用于处理SQL查询的一种机制,它允许程序逐行处理查询结果。在Oracle中,游标是至关重要的,尤其在进行复杂的交互式数据操作时。当一个应用程序尝试打开过多的游标时,...
总之,Oracle游标提供了处理查询结果的强大工具,使开发者能够灵活地在PL/SQL中操作数据。无论是隐式还是显式游标,都极大地增强了对数据库的交互能力,使得程序能根据查询结果进行适当的操作。理解并熟练运用游标是...
例如,执行存储过程: ```python cursor.callproc('stored_procedure_name', [param1, param2]) ``` 在处理大数据量时,cx_Oracle提供了批量操作的能力,可以显著提高性能: ```python cursor.executemany('...
在本例中,“Oracle存储过程实例使用显示游标”着重展示了如何在存储过程中调用函数,并通过游标来处理和更新数据。 首先,我们需要了解存储过程的基本结构。一个存储过程通常包含以下部分: 1. **声明部分**:在...
通过理解并熟练运用Oracle的存储过程和游标,开发者可以构建高效、模块化的数据库应用,提高代码复用性和数据库性能。在实际开发中,应根据需求合理选择使用函数或存储过程,并灵活运用游标处理复杂查询和结果集。
调用Oracle存储过程并处理返回的游标(Cursor)在Java中通常涉及以下步骤: 1. **建立数据库连接**:使用JDBC(Java Database Connectivity)驱动,通过`DriverManager.getConnection()`方法建立到Oracle数据库的...