`

PL/SQL学习三

阅读更多

游标的使用:

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  %isopenboolean类型变量,用来代表游标是否打开。

q  %notfoundboolean类型变量,如果最近的fetch语句没有返回一条记录,取true

q  %foundboolean类型变量,如果最近的fetch语句取到了记录,取true

q  %rowcountnumber类型变量,用来代表目前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循环。

 


 

分享到:
评论

相关推荐

    pl/sql最新中文手册

    3. **异常处理**:在PL/SQL中,异常处理是通过EXCEPTION关键字实现的,用于捕获并处理运行时错误。手册会详细解释如何定义和使用预定义及自定义异常。 4. **数据库操作**:PL/SQL与Oracle数据库紧密集成,可以执行...

    oracle10g_pl/sql

    - **块结构**:PL/SQL代码由声明、执行和异常处理三部分组成,包括BEGIN...END块、DECLARE...BEGIN...END块以及匿名块。 - **变量和常量**:PL/SQL支持各种数据类型,如NUMBER、VARCHAR2、DATE等,以及声明变量和...

    Oracle PL/SQL学习官方教材

    以下是对"Oracle PL/SQL学习官方教材"中可能包含的主要知识点的详细解释: 1. **基础概念**:首先,教材会介绍PL/SQL的基本概念,包括块(Block)、变量(Variable)、常量(Constant)、数据类型(Data Types)和...

    一个对数据库的操作工具PL/SQLpl/sqL工具

    3. **游标**:PL/SQL支持游标,允许用户逐行处理查询结果,这对于处理大量数据时非常有用。 4. **事务管理**:PL/SQL提供BEGIN、COMMIT、ROLLBACK等语句来管理事务,确保数据的一致性和完整性。 5. **异常处理**:...

    pl/sql 学习资料

    在这个“PL/SQL学习资料”压缩包中,包含了十一个PDF文件,覆盖了从基础到进阶的广泛主题。下面我们将详细探讨这些知识点。 1. **PL/SQL基础知识**: - PL/SQL结构:了解块的概念,包括声明部分、执行部分和异常...

    pl/sql例题代码pl/sql例题代码pl/sql例题代码

    在"plsql_day02"这个压缩包文件中,很可能包含了第二天学习PL/SQL时的一些示例代码。这些代码可能涉及到以下知识点: 1. **变量声明**:在PL/SQL中,我们首先需要声明变量来存储数据,比如`DECLARE`关键字用于定义...

    PL/SQL学习笔记

    PL/SQL程序通常是由声明、执行和异常处理三部分组成的。声明部分用于定义变量、常量、类型和子程序等。执行部分包括执行SQL语句、程序控制流语句,如IF语句和FOR循环等。异常处理部分用于捕获并处理程序运行中出现的...

    Oracle PL/SQL实战(待续)

    Oracle PL/SQL是一种强大的编程语言,它结合了SQL的数据处理能力与PL的程序设计...通过实践和学习"Oracle PL/SQL实战(待续)"的相关内容,我们可以提升在Oracle环境中解决问题的能力,更好地管理和优化数据库系统。

    PL/SQL学习资料

    这个“PL/SQL学习资料”压缩包包含了对这一编程语言深入理解和应用的关键知识点。 PL/SQL由三部分组成:声明部分、执行部分和异常处理部分。在声明部分,我们可以定义变量、常量、游标、记录类型等;执行部分用于...

    pl/sql学习笔记

    以下是对PL/SQL的学习笔记的详细解析: 1. **什么是PL/SQL语言** PL/SQL是Oracle数据库为数据库管理员和开发人员设计的一种编程语言。它扩展了SQL的功能,允许编写包含控制结构、变量、过程和函数的程序段,这些...

    PL/SQL学习教程,附笔记

    在学习PL/SQL的过程中,理解这些基本概念和结构是至关重要的。通过实践编写存储过程、函数和触发器,你可以逐渐掌握PL/SQL的强大功能,并利用它来解决实际的数据库编程问题。对于初学者来说,循序渐进、结合实例学习...

    oracle 中 pl/sql 只是学习方法

    PL/SQL的结构主要由三部分组成:声明部分、执行部分和异常处理部分。在声明部分,我们可以定义变量、常量、游标、存储过程和函数等。执行部分包含PL/SQL的语句,如赋值、控制流(如IF-THEN-ELSE、CASE)、循环(如...

    PL/SQL学习课件

    第三章“控制结构”深入讲解了PL/SQL中的流程控制语句,如IF-THEN-ELSE、CASE、WHILE循环、FOR循环等,这些都是编写逻辑复杂程序的基础。 第四章“使用复合数据类型”会涵盖Oracle中的多种数据类型,如数组、记录和...

    Oracle PL/SQL程序设计(第5版)(上下册)

    - **集合与记录**:学习如何使用PL/SQL中的集合和记录类型,这些结构可以帮助更高效地处理数据集。 - **游标**:介绍游标的使用方法,包括隐式游标和显式游标,以及如何利用游标遍历查询结果。 #### 四、PL/SQL中的...

    PL/SQL 基本知识

    总的来说,PL/SQL是Oracle数据库开发的重要工具,通过学习和掌握PL/SQL,开发者可以更好地利用Oracle数据库的强大功能,构建高效、稳定的企业级应用。而`jbpm.sql`文件可能包含的流程管理相关代码,正是PL/SQL在企业...

    PL/SQL下载

    对于初学者,可以从以下几个方面入手学习PL/SQL: 1. **基础语法**:理解PL/SQL的基本数据类型、变量声明、流程控制结构等。 2. **函数和过程**:掌握如何定义和调用自定义函数和过程。 3. **游标**:了解如何使用...

    PL/SQL编程基础知识

    ### PL/SQL编程基础知识 #### 一、PL/SQL简介 PL/SQL(Procedural Language for SQL)是一种过程化语言,它结合了SQL的数据操纵功能和过程化语言的...对于初学者来说,掌握这些基本概念是学习和应用PL/SQL的关键。

    PL/SQL开发文档1

    标题中提到的“PL/SQL开发文档1”,说明本文档是关于PL/SQL开发的入门级指导材料,面向希望学习使用PL/SQL进行数据库程序单元开发的用户。文档很可能是Oracle公司内部或其授权的培训机构用于教学目的的官方材料。 ...

    Oracle PL/SQL实例编程(PL/SQL经典书籍)

    3. **控制结构**:PL/PROCEDURE和PL/FUNCTION是PL/SQL的基本程序单元,前者不返回值,后者可以返回一个值。流程控制结构有IF-THEN-ELSIF-ELSE、CASE、FOR循环、WHILE循环和GOTO。 4. **SQL操作**:PL/SQL可以直接...

    PL/SQL Developer trial version问题

    3. **升级到新版本**:如果PL/SQL Developer已有更新版本,考虑升级到最新版,可能其中已经包含了更长的试用期限或者改进的用户体验。 4. **探索替代品**:如果你不愿意或无法支付许可费用,可以寻找其他开源或免费...

Global site tag (gtag.js) - Google Analytics