orcale 之 PL/SQL的游标

  根据我们之前了解到的情况,SQL是面向集合的,我们的查询结果一般包含多条数据,而在PL/SQL 中的变量一般只能存放一条数据,因此变量是无法满足我们的需求的。这时候我们就需要引入游标来为我们解决问题了。

  我们知道在 PL/SQL 中可以使用数据控制语言(DML)对数据进行操作,而在使用这些的时候 Orcale 会在内存中为其分配一个缓存区。而游标就是指向该缓存区的指针。它可以对查询结果集的每一行数据分别进行单独的处理。

  游标分为显式游标和隐式游标。显式游标是由用户声明操作的一种游标,而隐式游标是 Orcale 为所有的操作语言自动声明和操作的游标。

显式游标

  对于显式游标的操作分为:声明,打开,提取,关闭。

  1. 声明游标

    在游标的声明中定义了游标的名字而且这个游标和一个 SELECT 关联起来。除此之外显式游标必须在 DEXLARE 中。它的语法如下:

CURSOR <游标名> IS SELECT <语句>

  注意:这里的SELECT 语句是可以带有 UNION 或者 MINUS 的语句。

  2. 打开游标

    语法如下:

OPEN <游标名>;

  打开游标就会执行定义的 SELECT语句,执行完毕后,查询出来的结果会放入内存,游标的指针会指向查询结果的头部,

  3. 提取游标

    打开游标后的工作就是从查询出来的集合进行取值了,取值的语句是 FETCH 语法有两种格式:

FETCH <游标名> INTO <变量列表>;
FETCH <游标名> INTO PL/SQL 记录;

    FETCH 每执行一次游标会向后移动一次直到结束位置。

  4. 关闭游标

CLOSE <游标名>;

   5. 例子

--创建临时表
create table t_emp
(	tempne number(4) primary key,
	tename varchar2(20)
);
create table t_emp2
(	tempne number(4) primary key,
	tename varchar2(20)
);

DECLARE
  emp_no number(4); --定义变量
  emp_nanme varchar2(20);
CURSOR emp_cur IS --定义游标
  SELECT empno, ename
  FROM emp;
BEGIN
OPEN emp_cur; --打开游标
  --将第一行的数据放入变量中,之后游标后移
  FETCH emp_cur INTO emp_no, emp_nanme;
  LOOP
    EXIT WHEN NOT emp_cur%FOUND; --如果游标已经到末尾结束
    IF emp_no = ‘7839‘ THEN
      INSERT INTO t_emp values(emp_no,emp_nanme);
    else
      INSERT INTO t_emp2 values(emp_no,emp_nanme);
    END IF;
    FETCH emp_cur INTO emp_no, emp_nanme;
  END LOOP;
CLOSE emp_cur; --关闭游标
END;
/

  

时间: 2024-10-12 15:37:57

orcale 之 PL/SQL的游标的相关文章

在PL/SQL使用游标获取数据及动态SQL

1.游标概念: 当在PL/SQL块中执行DML(增删改)时,Oracle会为其分配上下文区(Context Area),游标是指向上下文区的指针 2.  游标分类: A.  隐式游标 a.  在PL/SQL中使用DML语句时自动创建隐式游标 b.  隐式游标自动声明.打开和关闭,其名为 SQL c.  通过检查隐式游标的属性可以获得最近执行的DML 语句的信息 d.  隐式游标的属性有: %FOUND – SQL 语句影响了一行或多行时为 TRUE %NOTFOUND – SQL 语句没有影响任

PL/SQL之--游标

一.游标简介 在PL/SQL中执行SELECT.INSERT.DELETE和UPDATE语句时,ORACLE会在内存中为其分配上下文区(Context Area),也称为缓冲区.游标是指向该区的一个指针.它提供了一种在多行结果集中对每一行数据分别进行单独处理的方法.用户可以用SQL语句逐一从游标中获取记录,并赋给主变量,交由主语言进一步处理. oracle中游标有如下两种: 静态游标:分为显式游标和隐式游标. ref游标:引用类型,类似于C中的指针. 二.静态游标 静态游标分为显式游标和隐式游标

PL/SQL 04 游标 cursor

--游标 declare  cursor 游标名字  is  查询语句;begin  其他语句;end; --游标的属性%FOUND%NOTFOUND%ISOPEN%ROWCOUNT(当前游标的指针位移量) --FETCH的两种形式FETCH cursor_name INTO var1, var2, -;FETCH cursor_name INTO record_var; --游标的FETCH循环LOOP  FETCH cursor INTO-  EXIT WHEN cursor%NOTFOUN

oracle pl/sql之游标

前情提要: 在通过select语句查询是,返回的结果通常是多行记录组成的集合.为此SQL提供 了游标机制.游标可以充当指针的作用,使应用程序设计语言一次只能处理查询记过中的一行.在Oracle中,可以使用隐式和显示两种游标.在pl/sql 中程序所有发出的DML和select语句,Oracle都会自动声明“隐式游标”.为了处理由select语句返回的一组记录,需要在pl/sql程序中申明和处理“显示游标”. 隐式游标 游标的主要属性如下: %found 布尔型属性,如果SQL语句至少影响一行,则

Oracle数据库PL/SQL存储过程游标触发器

创建一个添加FOOD的存储过程 create or replace procedure add_food_pro (name in varchar,price in number,description in varchar) as  begin insert into food (f_name,f_price,description)values(name,price,description); commit; end; --下面的代码是调用存储过程 begin add_food_pro('糖

[Oracle系列整理04] oracle pl/sql 基础

PL/SQL块中只能直接嵌入SELECT,DML(INSERT,UPDATE,DELETE)以及事务控制语句 (COMMIT,ROLLBACK,SAVEPOINT),而不能直接嵌入DDL语句(CREATE,ALTER,DROP)和DCL语句 (GRANT,REVOKE) 1.检索单行数据    1.1使用标量变量接受数据  v_ename emp.ename%type;  v_sal   emp.sal%type;  select ename,sal into v_ename,v_sal fro

PL/SQL详细介绍,设置oracle相关

1. 实现参照完整性      指若两个表之间具有主从关系(即主外键关系),当删除主表数据时,必须确保相关的从表数据已经被删除.  当修改主表的主键列数据时,必须确保相关从表数据已经被修改.为了实现级联删除,可在定义外部键约束时指定ON DELETE CASCADE关键字  alter table emp add constraint fk_deptno foreign key (deptno) references dept(deptno) on delete cascade; 实现级联更新,

数据库复习10——PL/SQL

数据库复习 CH10 PL/SQL 10.1 PL/SQL简介 PL/SQL是Oracle对SQL的过程化的扩展,PL/SQL可以实现SQL相关的过程化程序,并且能够以存储过程和函数的方式让一段SQL业务逻辑驻留在SQL服务器中,以便减少客户机计算任务并减少网络I/O 10.2 PL/SQL编程基础 (1)简介 PL/SQL编程框架为: DECLARE <Variable List> BEGIN <Extented SQL Execution> EXCEPTION <Exce

Oracle_PL/SQL(3) 游标

引言:PLSQL数据类型标量数据类型:数字类.字符类.日期类.布尔类(boolean).复合数据类型:记录(%rowtype).表.数组引用类型:REF CURSORLOB类型:BLOB.CLOB 1.系统定义的记录:%rowtype使用%rowtype属性定义记录变量:可以基于表或视图定义记录变量当使用%ROWTYPE属性定义记录变量时,记录成员个数,名称,类型与表或视图列的个数, 名称,类型完全相同. 1.1 在select语句中使用PL/SQL记录declare v_emp emp%row