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/VS Code 直接安装 打开 Cursor 或 VS Code,进入左侧扩展市场(Extensions)。 点击右上角 ... 菜单,选择 Install from VSIX。 浏览并选中下载的 Cursor-Fake-Machine-0.0.1.vsix 文件,完成...
Cursor中文使用手册详细知识点: 1. Cursor输入框使用方式: Cursor软件中的输入框是用户与软件进行交互的重要界面。用户可以在多种环境下使用Cursor输入框,比如CmdK、聊天界面或者终端环境中。使用时,用户需要...
Cursor.so是一款基于GPT的代码生成工具,它可以帮助开发者快速生成代码,提高开发效率。GPT是一种自然语言处理技术,可以根据输入的文本生成相应的文本。Cursor.so利用GPT技术,将开发者的自然语言描述转化为代码,...
https://github.com/boxqkrtm/com.unity.ide.cursor How to install 第一种方法: - Unity->Window->Package Manager - Click "+" left corner - Add package from git URL - Insert ...
Cursor安装包20241226是这类技术进步的一个具体体现,它代表了人工智能技术在软件应用层面的最新发展。Cursor作为一款AI软件,其安装包的发布,意味着用户无需支付任何费用即可尝试和学习人工智能技术。这无疑为对AI...
Cursor Mac 安装包版本240921llnho65ov 是一款专为Mac用户设计的代码编辑器。该安装包中包含了名为 Install Cursor.app 的应用程序,这款应用程序的核心功能是为了提高用户的编程效率而设计的。从描述中可以看出,...
Cursor作为一款新兴的智能代码编辑器,在处理这类大型项目时的性能表现尤为关键。 首先,Cursor在打开大型项目和文件的速度上表现突出。它利用优化的文件索引和加载机制,能快速解析项目结构和文件内容,大大缩短了...
Cursor Setup 0.44.11 x64.rar 是一款专门针对Cursor IDE编程软件的安装包,其版本号为0.44.11 x64,专为64位操作系统设计。从描述信息来看,“降级0.44,可能还可以续杯”暗示此版本可能是对之前版本的一个回退或者...
"Cursor多版本安装包"就是这样一个工具,提供了不同版本以适应不同的需求。本文将深入探讨Cursor这款软件/插件及其不同版本的安装包,以及在开发环境中如何管理和使用这些版本。 Cursor是一款可能用于文本编辑、...
Cursor是一款专为Windows平台设计的软件,最新版本为0.1.12-x64,其功能亮点在于利用先进的AI技术,尤其是与ChatGPT4相关的技术,来辅助用户进行编程工作。这款工具旨在简化代码编写过程,提供代码方案,并且帮助...
cursor插件包,从github下载的,方便无法上github的同学。不会用的确实没办法。该插件生成时间是2024-11-28的包,后续可能会更新。 下载包包含两个文件:cursor-fake-machine-0.0.1.vsix和cursor重置机器码说明.pdf ...
Cursor Mac版本0.1.11是一款专为Mac操作系统设计的新型代码编辑器,它旨在提供高效、便捷的编程环境,让开发者在Mac平台上能够更好地编写、管理和调试代码。这款编辑器的出现,是对现有市场上的众多代码编辑器的一个...
在MATLAB中,`cursor`是一个非常实用的功能,它允许用户在图形窗口中放置一个可交互的十字线,用于精确地选取数据点或进行可视化分析。`cursor`工具可以极大地提高开发过程中的数据处理和分析效率。在这个"matlab...
Cursor Linux版本0.1.11是一款专为Linux操作系统设计的新型代码编辑器,它旨在提供高效、便捷的代码编写体验。此版本的发布标志着Cursor编辑器在Linux平台上的一个新里程碑,它集成了多种先进的功能和优化,以满足...
"Cursor修改机器码"作为一个主题,可能指的是通过某种工具或脚本(如Cursor)来实现对机器码的修改。在全操作系统可用的语境下,这样的工具需要能够兼容不同的操作系统环境,如Windows、Linux和macOS等,并提供跨...
在信息技术领域,Cursor是一个软件名称,通常指代的是一种用于在计算机屏幕上移动和定位的设备,常被称为鼠标。然而,在此处的上下文中,Cursor似乎指代的是一款特定的软件,而非物理设备。根据给定的信息,Cursor...
Cursor 是一款基于 AI 技术的代码生成工具,它可以帮助开发人员自动生成代码,提高开发效率。 Cursor 是一款集成了 GPT-4 的免费 IDE 工具(目前免费),可以帮助用户快速编写、编辑和优化代码。 Cursor 是一款基于...
本案例中提到的软件Cursor,其版本0.45推出后,用户遇到了无法继续免费续费的问题,这可能是新版本中实施了新的收费策略或者是服务协议有所变更,导致原有的免费续费机制被移除。为了解决这一问题,部分用户选择了回...
Cursor Window是一款创新的代码编辑器,专为程序员和开发者设计,致力于提供高效、直观的代码编写体验。在0.1.11版本中,这款编辑器引入了一系列改进和功能,旨在提升开发者的生产力和舒适度。 首先,让我们深入...
cursor 0.45.1版本是一个特定的软件应用程序或功能更新,通常涉及到一种鼠标光标设计或软件工具,该工具可以在计算机操作系统中被安装以增强用户体验。在这个上下文中,cursor可能指的是一种光标修改工具,这类工具...