1.显式游标 ----对应于静态select语句
2.参数游标 ----对应于静态select语句
3.游标变量 REF cursor----对应于动态select 语句
4.游标表达式 CURSOR(subquery) --用于在plsql块中处理更加复杂的基于多张表的关联数据。为了在PL/SQL块中取得嵌套游标的数据,需要使用嵌套循环。
package里面不能定义游标。
记录类型
select * from dept;
declare
dept_record dept%rowtype;
begin
dept_record.deptno:=60;
dept_record.dname:='SUNNY';
dept_record.loc:='BEIJING';
INSERT INTO dept values dept_record;
end;
游标表达式的使用
DECLARE
TYPE refcursor IS REF CURSOR;
CURSOR dept_cursor (no number) IS
SELECT a.dname,CURSOR(SELECT ename,sal FROM emp WHERE deptno=a.deptno)
FROM dept a WHERE a.deptno=no;
empcur refcursor;
v_dname dept.dname%TYPE;
v_ename emp.ename%TYPE;
v_sal emp.sal%TYPE;
BEGIN
OPEN dept_cursor(&no);
LOOP
FETCH dept_cursor INTO v_ename,empcur;
EXIT WHEN dept_cursor%NOTFOUND;
dbms_output.put_line('部门名:'||v_dname);
LOOP
FETCH empcur INTO v_ename,v_sal;
EXIT WHEN empcur%NOTFOUND;
dbms_output.put_line('雇员名:'||v_ename||',工资'||v_sal);
END LOOP;
END LOOP;
CLOSE dept_cursor;
END;
游标For循环的用法:当使用游标FOR循环时,ORACLE会隐含地打开游标、提取游标数据并关闭游标。
DECLARE
CURSOR emp_cursor IS SELECT ename,sal FROM emp;
BEGIN
FOR emp_record IN emp_cursor LOOP
dbms_output.put_line('第'||emp_cursor%ROWCOUNT||'个雇员: '||emp_record.ename);
END LOOP;
END;
简化后:
BEGIN
FOR emp_record in(SELECT ename,sal FROM emp ) LOOP
dbms_output.put_line(emp_record.ename);
END LOOP;
END;
在显示游标中使用 FETCH ...BULK COLLECT INTO ...LIMIT 提取部分数据
DECLARE
TYPE name_array_type IS VARRAY(5) OF VARCHAR2(10);
name_array name_array_type;
CURSOR emp_cursor IS SELECT ename FROM emp;
row INT:=5;
v_count INT:=0;
BEGIN
OPEN emp_cursor;
LOOP
FETCH emp_cursor BULK COLLECT INTO name_array LIMIT row;
dbms_output.put('雇员名:');
FOR i IN 1 ..(emp_cursor%ROWCOUNT-v_count) LOOP
dbms_output.put(name_array(i)||' ');
END LOOP;
dbms_output.new_line;
v_count:=emp_cursor%ROWCOUNT;
EXIT when emp_cursor%NOTFOUND;
END LOOP;
CLOSE emp_cursor;
END;
分享到:
相关推荐
Cursor.so是一款基于GPT的代码生成工具,它可以帮助开发者快速生成代码,提高开发效率。GPT是一种自然语言处理技术,可以根据输入的文本生成相应的文本。Cursor.so利用GPT技术,将开发者的自然语言描述转化为代码,...
"Cursor多版本安装包"就是这样一个工具,提供了不同版本以适应不同的需求。本文将深入探讨Cursor这款软件/插件及其不同版本的安装包,以及在开发环境中如何管理和使用这些版本。 Cursor是一款可能用于文本编辑、...
Cursor是一款专为Windows平台设计的软件,最新版本为0.1.12-x64,其功能亮点在于利用先进的AI技术,尤其是与ChatGPT4相关的技术,来辅助用户进行编程工作。这款工具旨在简化代码编写过程,提供代码方案,并且帮助...
Cursor Mac版本0.1.11是一款专为Mac操作系统设计的新型代码编辑器,它旨在提供高效、便捷的编程环境,让开发者在Mac平台上能够更好地编写、管理和调试代码。这款编辑器的出现,是对现有市场上的众多代码编辑器的一个...
在MATLAB中,`cursor`是一个非常实用的功能,它允许用户在图形窗口中放置一个可交互的十字线,用于精确地选取数据点或进行可视化分析。`cursor`工具可以极大地提高开发过程中的数据处理和分析效率。在这个"matlab...
Cursor Linux版本0.1.11是一款专为Linux操作系统设计的新型代码编辑器,它旨在提供高效、便捷的代码编写体验。此版本的发布标志着Cursor编辑器在Linux平台上的一个新里程碑,它集成了多种先进的功能和优化,以满足...
Cursor 是一款基于 AI 技术的代码生成工具,它可以帮助开发人员自动生成代码,提高开发效率。 Cursor 是一款集成了 GPT-4 的免费 IDE 工具(目前免费),可以帮助用户快速编写、编辑和优化代码。 Cursor 是一款基于...
Cursor Window是一款创新的代码编辑器,专为程序员和开发者设计,致力于提供高效、直观的代码编写体验。在0.1.11版本中,这款编辑器引入了一系列改进和功能,旨在提升开发者的生产力和舒适度。 首先,让我们深入...
标题中的"PyPI 官网下载 | pyppeteer_ghost_cursor-0.2.3.tar.gz"表明这是一个从Python Package Index(PyPI)官方源下载的软件包,名为`pyppeteer_ghost_cursor`,版本号为0.2.3,格式为tar.gz。PyPI是Python社区的...
"cursor"是一款专为个性化电脑鼠标指针设计的软件,它提供了丰富的指针样式,让用户可以根据个人喜好定制自己的电脑界面。下面将详细探讨鼠标指针的相关知识点。 1. 鼠标指针的基本概念:鼠标指针,也称为光标,是...
Cursor Mac 安装包 版本240921llnho65ov Al代码编辑器 旨在让你工作效率非凡 Cursor是用Al编写代码的最佳方式
在Android开发中,`Cursor` 是一个非常重要的概念,它用于从SQLite数据库中检索数据。`Cursor` 类就像一个指针,可以遍历查询结果中的每一行数据。本篇文章将详细介绍如何使用`Cursor`以及在实际代码中的应用。 ...
### Android Cursor 的用法 #### 一、简介 在 Android 开发中,Cursor 是一个非常重要的类,主要用于处理数据查询结果。它提供了一个简洁的方法来访问数据库查询的结果集,并允许开发者方便地遍历这些结果。对于...
Cursor Linux版本v-0.1.12是一款专为Linux操作系统设计的新型代码编辑器,旨在提供高效、灵活且功能丰富的编程环境。该编辑器针对Linux用户进行了优化,旨在满足开发人员在日常编码工作中对速度、性能和自定义性的...
Cursor 是一款基于 AI 技术的代码生成工具,它可以帮助开发人员自动生成代码,提高开发效率。 Cursor 是一款基于人工智能技术的代码生成工具,它可以根据人们的需求和输入自动化生成代码。 版本: Cursor Setup 0.35....
Cursor 是一款基于 AI 技术的代码生成工具,它可以帮助开发人员自动生成代码,提高开发效率。 Cursor 是一款基于人工智能技术的代码生成工具,它可以根据人们的需求和输入自动化生成代码。安装程序 Cursor Setup ...
### Cursor的部分操作 #### 概述 在Android开发过程中,`Cursor`是一个非常重要的类,主要用于与数据库交互,实现数据的检索、更新等操作。通过`Cursor`,开发者可以轻松地进行数据查询,并且能够方便地遍历结果...
Cursor 是一款集成 AI 的编程环境,致力于为开发者提供智能代码生成、错误修复、代码优化等多项功能。通过与 GPT-4 等先进的语言模型整合,Cursor 不仅能够理解代码上下文,还能根据开发者的需求实时生成代码和提供...
Cursor Mac版本v0.1.12是一款专为Mac用户设计的全新代码编辑器,它致力于提供高效、直观且功能丰富的编程环境。该版本的发布带来了许多改进和新特性,旨在提升开发者的代码编写体验。 首先,Cursor的核心是其强大的...
Cursor Setup 0.2.33-x64.exe