oracle之游标(九)
游标(cursor)可以被看作指向结果集(a set of rows)中一行的指针(pointer)。在oracle数据库中可以使用显示或隐式两种游标。
隐式游标:
在执行一个sql语句时,oracle服务器将自动创建一个隐式游标,这个游标是内存中处理该语句的工作区域,其中存储了执行SQL语句的结果.通过游标的属性可获得sql语句执行的结果以及游标状态信息。
游标的主要属性如下:
%found 布尔属性 如果sql语句至少影响一行 则为true 否则为false
%notfound 布尔属性 与%found相反。
%isopen 布尔属性 游标是否打开 打开为true 否则为false
%rowcount 数字属性 返回受sql语句影响的行数
怎么来使用这些属性呢?
则可以通过 “sql属性名 “来查看结果
//%rowcount 用来检查受影响的行
declare emp_row emp%rowtype; begin select * into emp_row from emp where empno=7369; dbms_output.put_line(sql%rowcount); end; / 1 //返回的结果为1
//%found用来检查是否影响到了 begin update emp set sal=2000 where empno=7369; if sql%found then dbms_output.put_line('更新记录成功影响了'||sql%rowcount||'行'); else dbms_output.put_line('未更新记录'); end if; end; /
/
更新记录成功 影响了1行
// %notfound
//%isopen
一以上两个的使用方式参考 %found进行理解。
另外一种隐式游标cursor for loop可用于处理sql语句的结果集
begin for rec in (select * from emp) loop dbms_output.put_line(rec.empno||'/'||rec.ename||'/'||rec.job||'/'||rec.mgr||'/'||rec.hiredate||'/'||rec.sal||'/'||rec.comm||'/'||rec.deptno); end loop; end; /
显示游标
是在PL/SQL程序中使用包含select语句来声明的游标。如果需要处理从数据库中检索的一组记录,则可以使用显示游标.使用显示游标处理数据需要四个步骤:声明游标,打开游标,检索数据,关闭游标。
1、 声明游标
声明游标就是通过定义游标的名称,游标的特性来声明游标,以及打开游标后就可调用查询语句,声明的语法如下:
Cursor cursor_name[parameter[,parameter]….]
[return return_type] is select_statement;
Parameter作为游标的输入参数,它可以让用户在打开游标式,向游标传递值;语法如下:
Parameter_name [in] datatype[{:=|default} expression]
举例:
declare cursor emp_cursor (pno in number(4) default 7369) is select * from emp where empno=pno;
2、 打开游标
就是指执行声明游标时指定的查询语句。打开的方式只需使用open打开语法:
Open cursor_name(参数);
如果没有指定参数就采用默认值执行select语句
3、 检索数据
检索数据就是从检索到的结果集中获取数据保存到变量中,以便变量进行处理。
4、 关闭游标
分享到:
相关推荐
Oracle数据库游标是数据库管理系统中用于处理查询结果的一种机制,它允许程序逐行处理查询结果,而不是一次性加载所有数据。在Oracle中,游标对于实现复杂的数据操作和控制流程至关重要,特别是在存储过程和触发器中...
### Oracle中的游标详解 #### 一、引言 在Oracle数据库中,游标是一种非常重要的机制,它允许用户在程序中对查询结果进行逐行处理。游标分为两种主要类型:**隐式游标**和**显示游标**。此外,还可以利用游标进行...
以下是关于Oracle游标使用的一些关键知识点: 1. **游标的基本概念**: 游标(Cursor)是一种机制,它允许我们遍历和操作由SQL查询返回的结果集。通过游标,我们可以控制数据的读取顺序,一次只处理一行,或者在...
Oracle 数据库游标的使用方法 Oracle 数据库游标是指在查询返回结果超过一行时,需要使用的显式游标。用户不能使用 select into 语句,而是需要使用游标来处理多行查询结果。在 PL/SQL 中,隐式游标会在查询开始时...
Oracle数据库游标是数据库编程中的一个重要概念,尤其在处理大量数据时,它们提供了一种有效且灵活的方法。游标允许程序逐行访问查询结果集,而不是一次性加载所有数据。这在处理复杂的数据操作,如循环处理、条件...
1. 声明游标:声明一个游标变量,指定与之关联的SQL查询。 ```sql DECLARE cursor_name CURSOR FOR SELECT column1, column2, ... FROM table_name WHERE condition; ``` 2. 打开游标:使用`OPEN`语句开始处理...
oracle笔记游标的使用,游标的详细代码案例,游标知识点笔记!
oracle数据库游标实验报告!oracle数据库游标实验报告!oracle数据库游标实验报告!
Oracle 游标概述 Oracle 游标是 Oracle 数据库中的一种重要概念,用于查询数据库,获取记录集合(结果集)的指针。游标可以看作是一个临时表,你可以对其每一行的数据进行任意的操作。本文将对 Oracle 游标的概念、...
下面,我们将深入探讨Oracle游标的使用示例及其相关的知识点。 首先,游标的基本概念是它提供了一种方式来跟踪并控制SQL查询的结果集。在Oracle中,游标有四种状态:未打开、已打开、正在提取和已关闭。以下是一个...
游标是Oracle数据库中一个重要的概念,它是一种在内存中用于存储SQL查询结果的临时工作...随着Oracle数据库的不断更新和发展,对于初学者和数据库管理员来说,学习和使用游标是数据库管理和编程中必不可少的技能之一。
Oracle数据库中的游标是处理查询结果集的一种重要机制,尤其在需要逐行处理多行数据时。游标允许我们按照需要遍历查询结果,并对每一行进行操作。...正确理解和使用游标是开发高效PL/SQL程序的关键技能之一。
Oracle数据库游标是PL/SQL编程中不可或缺的一部分,它们允许程序逐行处理查询结果,提供了更灵活的数据操作方式。在Oracle数据库中,游标主要分为两种类型:隐式游标和显式游标。 1. **隐式游标**: - 当在PL/SQL...
多维度查询时通常需要建立多个游标循环,查询效率无法得到保障,现在通过游标和substr()函数相结合的方式提高查询效率
Oracle游标是数据库编程中非常重要的一个概念,主要用于处理SQL查询的结果集。游标允许我们按需逐行处理数据,而不是一次性加载所有结果。这里详细介绍了Oracle中的三种游标类型:隐式游标、显式游标和REF游标。 1....
2. **Oracle游标**:游标允许我们处理查询结果集中的每一行数据。在`oracle游标.txt`中,你可以学习到如何声明、打开、读取和关闭游标。游标在处理大量数据时非常有用,特别是在需要逐行处理或循环遍历结果集的情况...
该文件讲解了Oracle数据库中函数游标的创建以及包的定义,对数据库有更深层次的了解
Oracle游标是PL/SQL编程中的重要组成部分,主要用于处理单行或多行查询结果。游标允许程序员逐行处理查询结果,而不是一次性加载所有数据。在Oracle中,游标分为显式游标和隐式游标。 1. **隐式游标**:在PL/SQL中...
### Oracle游标详解 在Oracle数据库中,游标(Cursor)是处理数据集的一个关键机制,主要用于执行查询并逐行处理结果集。游标可以被视为一个临时存储区,用于保存SELECT语句的结果集,允许程序对这些结果进行迭代...