两种类型:
    隐式:
        执行INSERT、UPDATE、DELETE 或者只返回一条结果的SELECT语句时默认创建。
    显式:
         执行返回多条结果的SELECT语句时才能创建显式游标,创建时游标可以存储多行记录,但是同一个时间点上只能对一条记录进行处理。

隐式游标
隐式游标属性:
属性
   返回类型

例子

%FOUND

至少一条记录受影响(或者返回)时返回TRUE

SQL%FOUND

没有记录受影响(或者返回)时返回FALSE

%NOTFOUND

没有记录受影响(或者返回)时返回TRUE

SQL%NOTFOUND

至少一条记录受影响(或者返回)时返回FALSE

%ROWCOUNT

返回受影响的记录条数

SQL%ROWCOUNT

例子:

DECLARE  var_rows number(5);
BEGIN
  UPDATE employee 
  SET salary = salary + 1000;
  IF SQL%NOTFOUND THEN
    dbms_output.put_line('None of the salaries where updated');
  ELSIF SQL%FOUND THEN
    var_rows := SQL%ROWCOUNT;
    dbms_output.put_line('Salaries for ' || var_rows || 'employees are updated');
  END IF; 
END; 

显式游标
创建格式:
CURSOR cursor_name IS select_statement;
使用:
  • 在声明部分声明显式游标.
  • 在执行部分打开游标.
  • 将从游标里获取到的数据放到PL/SQL变量或者记录里.
  • 关闭游标.

1) 声明游标:

   DECLARE
   CURSOR cursor_name IS 
   返回多条记录的SELECT语句; 

2) 打开游标:

    OPEN cursor_name;
3) 取数据放到PL/SQL变量或者记录里:

FETCH cursor_name INTO record_name;

    FETCH cursor_name INTO variable_list;  
4) 关闭游标:
    CLOSE cursor_name;
5)注意:  
    当取数据(数据库里一行记录)存到记录里面时,记录和游标的数据结构必须一致。
    当取数据(数据库里一行记录)存到多个变量里时,变量的顺序和游标列的顺序一致。
    游标打开后,第一行被指定为当前行,每当数据被取到变量或者记录里,游标指向下一行。

     试图打开一个在前面操作中没有关闭的游标,程序会报错。

当游标移到最后一行记录的后面,再取数据时,程序会报错。

例子:
1> DECLARE 
2>    emp_rec emp_tbl%rowtype;
3>    CURSOR emp_cur IS 
4>    SELECT *
5>    FROM emp_tbl
6>    WHERE salary > 10; 
7> BEGIN 
8>    OPEN emp_cur; 
9>    FETCH emp_cur INTO emp_rec; 
10>      dbms_output.put_line (emp_rec.first_name || '  ' || emp_rec.last_name); 
11>   CLOSE emp_cur; 
12> END; 

显式游标属性:

属性

返回值

例子

%FOUND

至少获取一条数据时返回TRUE

Cursor_name%FOUND

没有获取到数据时返回FALSE

%NOTFOUND

没有获取到数据时返回TRUE Cursor_name%NOTFOUND
至少获取一条数据时返回FALSE

%ROWCOUNT

获取到的数据条数

Cursor_name%ROWCOUNT

没有取到数据时,报错

%ISOPEN

游标打开时返回TRUE

Cursor_name%ISNAME

游标关闭时返回FALSE

使用简单循环:

1> DECLARE 
2>   CURSOR emp_cur IS 
3>   SELECT first_name, last_name, salary FROM emp_tbl; 
4>   emp_rec emp_cur%rowtype; 
5> BEGIN 
6>   IF NOT emp_cur%ISOPEN THEN 
7>      OPEN emp_cur; 
8>   END IF; 
9>   LOOP 
10>     FETCH emp_cur INTO emp_rec; 
11>     EXIT WHEN emp_cur%NOTFOUND; 
12>     dbms_output.put_line(emp_cur.first_name || ' ' ||emp_cur.last_name 
13>     || ' ' ||emp_cur.salary); 
14>  END LOOP;
15>  END; 
16>  / 

使用While循环:

9>   FETCH sales_cur INTO sales_rec;  
10>  WHILE sales_cur%FOUND THEN  
11>  LOOP 
12>    dbms_output.put_line(emp_cur.first_name || ' ' ||emp_cur.last_name 
13>    || ' ' ||emp_cur.salary); 
15>    FETCH sales_cur INTO sales_rec; 
16>  END LOOP; 

使用FOR循环:

1> DECLARE 
2>  CURSOR emp_cur IS 
3>  SELECT first_name, last_name, salary FROM emp_tbl; 
4>  emp_rec emp_cur%rowtype; 
5> BEGIN 
6>  FOR emp_rec in sales_cur 
7>  LOOP  
8>  dbms_output.put_line(emp_cur.first_name || ' ' ||emp_cur.last_name 
9>    || ' ' ||emp_cur.salary);  
10> END LOOP; 
11>END;
12> /

带参数游标

格式:CURSOR cursor_name(parameter_name1 type1,parameter_name2 datetype type2..) IS select_statement;
例子:
1)定义
CURSOR c_emp(no IN emp.empno%TYPE) --或者(no NUMBER)
IS
SELECT * FROM emp
WHERE
empno = no; 2)使用
OPEN c_emp('no1')
FOR r_emp IN c_emp('no1') LOOP...

使用FOR UPDATE 和 WHERE CURRENT的游标

以下内容摘自《Oracle PL/SQL by Example》
使用FOR UPDATE 和 WHERE CURRENT的游标:
FOR UPDATE 能锁定希望更新的行,commit或者rollback 后才会释放锁
没有commit或者rollback时可以在游标中使用WHERE CURRENT OF 检索最新的数据。
 使用:
    在游标定义结尾处加上
    FOR UPDATE [OF item_name]
        
例子:
 1)
        DECLARE
          CURSOR c_course IS
            SELECT course_no,cost
            FROM course FOR UPDATE [OF cost];
        BEGIN
           FOR r_course IN c_course
           LOOP
             IF r_course.cost < 2500
             THEN
               UPDATE course
               SET cost = r_course.cost + 10
               WHERE course_no = r_course.course_no;
             END IF;
            END LOOP;
          END;
          
2) 使用WHERE CURRENT OF子句,可以不用在UPDATE语句中添加对应的WHERE条件
        DECLARE
          CURSOR c_course IS
            SELECT course_no,cost
            FROM course
            WHERE cost < 2500
            FOR UPDATE [OF cost];
        BEGIN
           FOR r_course IN c_course
           LOOP
             UPDATE course
               SET cost = r_course.cost + 10
             WHERE CURRENT OF c_course;
            END LOOP;
          END;




PL/SQL学习(三)游标的更多相关文章

  1. PL/SQL学习笔记之游标

    一:游标 Oracle会创建一个上下文区域,用于处理SQL语句,其中包含需要处理的语句.处理结果等等. 游标指向这一上下文的区域. PL/SQL通过控制游标在上下文区域移动,来获取SQL语句的结果信息 ...

  2. PL/SQL -->隐式游标(SQL%FOUND)

    PL/SQL -->隐式游标(SQL%FOUND) 分类: SQL/PLSQL 基础2010-12-22 16:23 4084人阅读 评论(0) 收藏 举报 sqlexceptionoracle ...

  3. ORALCE PL/SQL学习笔记

    ORALCE  PL/SQL学习笔记 详情见自己电脑的备份数据资料

  4. PL/SQL学习笔记_02_游标

    在 PL/SQL 程序中,对于处理多行记录的事务经常使用游标来实现. 为了处理 SQL 语句, ORACLE 必须分配一片叫上下文( context area )的区域来处理所必需的信息,其中包括要处 ...

  5. PL/SQL学习笔记(三)

    -----创建一个序列,再创建一个表(主键是数字),通过序列生成该表的主键值. create table mytb1( m_id number primary key, m_name ) not nu ...

  6. Oracle之PL/SQL学习笔记

    自己在学习Oracle是做的笔记及实验代码记录,内容挺全的,也挺详细,发篇博文分享给需要的朋友,共有1w多字的学习笔记吧.是以前做的,一直在压箱底,今天拿出来整理了一下,给大家分享,有不足之处还望大家 ...

  7. 五、PL/SQL循环、游标、函数和过程

    --PL/SQL基础知识学习 --一.PL/SQL语句块,基础语法格式 DECLARE --变量声明列表 info varchar(25); --变量声明 stu_unm integer := 15; ...

  8. [Oracle] PL/SQL学习笔记

    -- 1. 使用一个变量 declare -- Local variables here v_name ); begin -- Test statements here select t.user_n ...

  9. PL/SQL — 显式游标

    一.游标的相关概念及特性 1.定义 通过游标方式定位到结果集中某个特定的行,然后根据业务需求对该行进行相应特定的操作. 2.分类 显示游标: 用户自定义游标,用于处理select语句返回的多行数据. ...

随机推荐

  1. 如何用jQuery实现在鼠标滚动后导航栏保持固定

    要实现如下效果,鼠标滚动后,上方导航栏置顶固定 关键html代码: <div class="header-bottom"> <div class="co ...

  2. [微信小程序] 终于可以愉快的使用 async/await 啦

    [小程序] 终于可以愉快的使用 async/await 啦 这篇文章主要是想说一下 怎么在微信小程序中使用async/await从而逃离回调地狱 背景 最近一直在搞微信小程序 用的语言是TypeScr ...

  3. mysql.cnf 配制文件详解

    代码如下: [client]port = 3306socket = /tmp/mysql.sock [mysqld]port = 3306socket = /tmp/mysql.sock basedi ...

  4. Javascript数组,String对象,Math对象,Date对象,正则表达式

    标题栏的滚动<html><head><title>山西众创金融</title></head>function init(){ //1.拿到标 ...

  5. 读写应用程序数据-CoreData

    coreData数据最终的存储类型可以是:SQLite数据库.XML.二进制.内存里.自定义的数据类型. 和SQLite区别:只能取出整个实体记录,然后分解,之后才能得到实体的某个属性. 1.创建工程 ...

  6. iOS 网络编程:XML解析

    1 XML文档结构 1.1 简介 XML 指可扩展标记语言(eXtensible Markup Language).XML 被设计用来传输和存储数据.其非常像HTML的标记语言,但与之不同的是,XML ...

  7. linux下安装apache2.4

    linux安装Apache2步骤如下 apr 下载地址 http://mirrors.cnnic.cn/apache//apr/apr-1.5.2.tar.gz 安装过程 tar -xzvf apr- ...

  8. HTTP请求、响应报文格式

    HTTP请求报文格式: HTTP请求报文主要由请求行.请求头部.空行以及请求正文4部分组成 1,请求行由3部分组成,分别为:请求方式,URI(注意这里不是URL)以及协议版本组成,之间由空格分隔 请求 ...

  9. hibernate篇章六--demo(Hibernate之第1解之-hibernate_demo_1)

    准备工作做好了,开始Hibernate: 1:建立包:package:dao.model.service.util包: 2:开始model实体类Student:id,sname生成getter/set ...

  10. c中计时的几种方法

    C计时的几种方法说明及例程 1. 使用clock() 函数 头文件:<time.h> clock()函数,返回“自程序启动到调用该函数,CPU时钟的计时单元数(clock tick)” 每 ...