游标的使用:
n 作用:
q 我们的select语句的结果集中只能有一条记录,这给程序带来了很大的限制,比如说,我们现在想把emp表中的每一条记录,按照一些复杂的逻辑取出来进行显示或更新,这个时候需要某种机制在表中的多条记录之间进行循环,这种机制就是游标。游标就是指在某个结果集上的指针,通过这个指针的移动,我们得以遍历整个结果集,这样我们就可以一次取出多条记录,然后按照程序的逻辑一条一条地进行处理。
n 典型的游标使用的步骤包括以下几步:
q 声明游标
q 打开游标
q 处理游标中的数据
q 关闭游标
n 典型示例:
declare
cursor c is select * from emp;
v_emp c%rowtype;
begin
open c;
fetch c into v_emp;
dbms_output.put_line(v_emp.ename);
close c;
end;
n 最常用的游标属性有以下四个:
q %isopen,boolean类型变量,用来代表游标是否打开。
q %notfound,boolean类型变量,如果最近的fetch语句没有返回一条记录,取true。
q %found,boolean类型变量,如果最近的fetch语句取到了记录,取true。
q %rowcount,number类型变量,用来代表目前fetch到的记录的总行数。
q loop循环遍历游标
n While循环遍历游标
n For循环遍历游标
n 带参数的游标
n 使用游标更新结果集
游标的简单使用:
declare
cursor c is select * from emp order by ename desc;
v_emp c%rowtype;
begin
open c;
fetch c into v_emp;
dbms_output.put_line(v_emp.ename);
close c;
end;
|
利用loop循环和%notfound属性,我们可以实现游标的遍历,下面给出一个例子:
declare
cursor c is
select * from emp;
v_emp emp%rowtype;
begin
open c;
loop
fetch c into v_emp;
exit when (c%notfound);
dbms_output.put_line(v_emp.ename);
end loop;
close c;
end;
|
利用while循环配合%found属性,我们也可以遍历游标,例:
declare
cursor c is
select * from emp;
v_emp emp%rowtype;
begin
open c;
fetch c into v_emp;
while (c%found) loop
dbms_output.put_line(v_emp.ename);
fetch c into v_emp;
end loop;
close c;
end;
|
利用for循环遍历游标最简单,例如:
declare
cursor c is
select * from emp;
begin
for v_emp in c loop
dbms_output.put_line(v_emp.ename);
end loop;
end;
这个时候,我们不需要打开游标,也不需要关闭,甚至不用声明循环变量v_emp,这一切都在for循环内部自动完成,正因为for循环处理游标是如此简单,因此大多数时候我们所使用的都是for循环。
|
分享到:
相关推荐
3. **异常处理**:在PL/SQL中,异常处理是通过EXCEPTION关键字实现的,用于捕获并处理运行时错误。手册会详细解释如何定义和使用预定义及自定义异常。 4. **数据库操作**:PL/SQL与Oracle数据库紧密集成,可以执行...
- **块结构**:PL/SQL代码由声明、执行和异常处理三部分组成,包括BEGIN...END块、DECLARE...BEGIN...END块以及匿名块。 - **变量和常量**:PL/SQL支持各种数据类型,如NUMBER、VARCHAR2、DATE等,以及声明变量和...
以下是对"Oracle PL/SQL学习官方教材"中可能包含的主要知识点的详细解释: 1. **基础概念**:首先,教材会介绍PL/SQL的基本概念,包括块(Block)、变量(Variable)、常量(Constant)、数据类型(Data Types)和...
3. **游标**:PL/SQL支持游标,允许用户逐行处理查询结果,这对于处理大量数据时非常有用。 4. **事务管理**:PL/SQL提供BEGIN、COMMIT、ROLLBACK等语句来管理事务,确保数据的一致性和完整性。 5. **异常处理**:...
在这个“PL/SQL学习资料”压缩包中,包含了十一个PDF文件,覆盖了从基础到进阶的广泛主题。下面我们将详细探讨这些知识点。 1. **PL/SQL基础知识**: - PL/SQL结构:了解块的概念,包括声明部分、执行部分和异常...
3. **变量声明和赋值**:在PL/SQL中,变量必须先声明后使用,可以使用`:=`符号进行赋值。同时,PL/SQL支持局部变量和全局变量。 4. **流程控制**:包括IF-THEN-ELSE、CASE语句用于条件判断,WHILE和FOR循环用于迭代...
PL/SQL程序通常是由声明、执行和异常处理三部分组成的。声明部分用于定义变量、常量、类型和子程序等。执行部分包括执行SQL语句、程序控制流语句,如IF语句和FOR循环等。异常处理部分用于捕获并处理程序运行中出现的...
Oracle PL/SQL是一种强大的编程语言,它结合了SQL的数据处理能力与PL的程序设计...通过实践和学习"Oracle PL/SQL实战(待续)"的相关内容,我们可以提升在Oracle环境中解决问题的能力,更好地管理和优化数据库系统。
这个“PL/SQL学习资料”压缩包包含了对这一编程语言深入理解和应用的关键知识点。 PL/SQL由三部分组成:声明部分、执行部分和异常处理部分。在声明部分,我们可以定义变量、常量、游标、记录类型等;执行部分用于...
以下是对PL/SQL的学习笔记的详细解析: 1. **什么是PL/SQL语言** PL/SQL是Oracle数据库为数据库管理员和开发人员设计的一种编程语言。它扩展了SQL的功能,允许编写包含控制结构、变量、过程和函数的程序段,这些...
在学习PL/SQL的过程中,理解这些基本概念和结构是至关重要的。通过实践编写存储过程、函数和触发器,你可以逐渐掌握PL/SQL的强大功能,并利用它来解决实际的数据库编程问题。对于初学者来说,循序渐进、结合实例学习...
PL/SQL的结构主要由三部分组成:声明部分、执行部分和异常处理部分。在声明部分,我们可以定义变量、常量、游标、存储过程和函数等。执行部分包含PL/SQL的语句,如赋值、控制流(如IF-THEN-ELSE、CASE)、循环(如...
ORACLE PL/SQL是从入门到精通的专业知识,涵盖了数据库开发与管理的多个方面,包括...这本书籍将为读者提供一个全面、系统的学习路径,帮助数据库管理员、开发人员深入理解并掌握ORACLE PL/SQL的强大功能和应用技巧。
Oracle PL/SQL是一种强大的编程语言,它结合了SQL(结构化查询语言)的数据库操作功能与PL/SQL的程序设计特性,广泛应用于Oracle数据库的开发和管理。这本书"Oracle PL/SQL从入门到精通"的配套源代码,显然是为了...
第三章“控制结构”深入讲解了PL/SQL中的流程控制语句,如IF-THEN-ELSE、CASE、WHILE循环、FOR循环等,这些都是编写逻辑复杂程序的基础。 第四章“使用复合数据类型”会涵盖Oracle中的多种数据类型,如数组、记录和...
- **集合与记录**:学习如何使用PL/SQL中的集合和记录类型,这些结构可以帮助更高效地处理数据集。 - **游标**:介绍游标的使用方法,包括隐式游标和显式游标,以及如何利用游标遍历查询结果。 #### 四、PL/SQL中的...
总的来说,PL/SQL是Oracle数据库开发的重要工具,通过学习和掌握PL/SQL,开发者可以更好地利用Oracle数据库的强大功能,构建高效、稳定的企业级应用。而`jbpm.sql`文件可能包含的流程管理相关代码,正是PL/SQL在企业...
对于初学者,可以从以下几个方面入手学习PL/SQL: 1. **基础语法**:理解PL/SQL的基本数据类型、变量声明、流程控制结构等。 2. **函数和过程**:掌握如何定义和调用自定义函数和过程。 3. **游标**:了解如何使用...
3. **控制结构**:PL/PROCEDURE和PL/FUNCTION是PL/SQL的基本程序单元,前者不返回值,后者可以返回一个值。流程控制结构有IF-THEN-ELSIF-ELSE、CASE、FOR循环、WHILE循环和GOTO。 4. **SQL操作**:PL/SQL可以直接...
### PL/SQL编程基础知识 #### 一、PL/SQL简介 PL/SQL(Procedural Language for SQL)是一种过程化语言,它结合了SQL的数据操纵功能和过程化语言的...对于初学者来说,掌握这些基本概念是学习和应用PL/SQL的关键。