`
sunny.yang
  • 浏览: 32192 次
  • 性别: Icon_minigender_2
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

cursor

阅读更多

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-Fake-Machine-0.0.1.vsix 是为 Cursor IDE 设计的插件工具,帮助开发者在测试、调试或教学场景中,灵活申请 Cursor 的请求计数,确保开发流程的连贯性

    方式一:通过 Cursor/VS Code 直接安装 打开 Cursor 或 VS Code,进入左侧扩展市场(Extensions)。 点击右上角 ... 菜单,选择 Install from VSIX。 浏览并选中下载的 Cursor-Fake-Machine-0.0.1.vsix 文件,完成...

    Cursor中文使用手册PDF

    Cursor中文使用手册详细知识点: 1. Cursor输入框使用方式: Cursor软件中的输入框是用户与软件进行交互的重要界面。用户可以在多种环境下使用Cursor输入框,比如CmdK、聊天界面或者终端环境中。使用时,用户需要...

    cursor,程序员的福音,Cursor可以帮助开发者快速生成代码,提高开发效率

    Cursor.so是一款基于GPT的代码生成工具,它可以帮助开发者快速生成代码,提高开发效率。GPT是一种自然语言处理技术,可以根据输入的文本生成相应的文本。Cursor.so利用GPT技术,将开发者的自然语言描述转化为代码,...

    unity中配置Cursor包

    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安装包,想学习的Cursor可以免费使用

    Cursor安装包20241226是这类技术进步的一个具体体现,它代表了人工智能技术在软件应用层面的最新发展。Cursor作为一款AI软件,其安装包的发布,意味着用户无需支付任何费用即可尝试和学习人工智能技术。这无疑为对AI...

    Cursor Mac 安装包 版本240921llnho65ov

    Cursor Mac 安装包版本240921llnho65ov 是一款专为Mac用户设计的代码编辑器。该安装包中包含了名为 Install Cursor.app 的应用程序,这款应用程序的核心功能是为了提高用户的编程效率而设计的。从描述中可以看出,...

    Cursor在处理大型项目时的性能表现.pdf

    Cursor作为一款新兴的智能代码编辑器,在处理这类大型项目时的性能表现尤为关键。 首先,Cursor在打开大型项目和文件的速度上表现突出。它利用优化的文件索引和加载机制,能快速解析项目结构和文件内容,大大缩短了...

    Cursor Setup 0.44.11 x64.rar

    Cursor Setup 0.44.11 x64.rar 是一款专门针对Cursor IDE编程软件的安装包,其版本号为0.44.11 x64,专为64位操作系统设计。从描述信息来看,“降级0.44,可能还可以续杯”暗示此版本可能是对之前版本的一个回退或者...

    cursor多版本安装包

    "Cursor多版本安装包"就是这样一个工具,提供了不同版本以适应不同的需求。本文将深入探讨Cursor这款软件/插件及其不同版本的安装包,以及在开发环境中如何管理和使用这些版本。 Cursor是一款可能用于文本编辑、...

    Cursor下载安装包-win

    Cursor是一款专为Windows平台设计的软件,最新版本为0.1.12-x64,其功能亮点在于利用先进的AI技术,尤其是与ChatGPT4相关的技术,来辅助用户进行编程工作。这款工具旨在简化代码编写过程,提供代码方案,并且帮助...

    cursor-fake-machine-0.0.1.vsix

    cursor插件包,从github下载的,方便无法上github的同学。不会用的确实没办法。该插件生成时间是2024-11-28的包,后续可能会更新。 下载包包含两个文件:cursor-fake-machine-0.0.1.vsix和cursor重置机器码说明.pdf ...

    全新代码编辑器 Cursor Mac版本0.1.11

    Cursor Mac版本0.1.11是一款专为Mac操作系统设计的新型代码编辑器,它旨在提供高效、便捷的编程环境,让开发者在Mac平台上能够更好地编写、管理和调试代码。这款编辑器的出现,是对现有市场上的众多代码编辑器的一个...

    matlab开发-cursor

    在MATLAB中,`cursor`是一个非常实用的功能,它允许用户在图形窗口中放置一个可交互的十字线,用于精确地选取数据点或进行可视化分析。`cursor`工具可以极大地提高开发过程中的数据处理和分析效率。在这个"matlab...

    全新代码编辑器 Cursor Linux版本0.1.11

    Cursor Linux版本0.1.11是一款专为Linux操作系统设计的新型代码编辑器,它旨在提供高效、便捷的代码编写体验。此版本的发布标志着Cursor编辑器在Linux平台上的一个新里程碑,它集成了多种先进的功能和优化,以满足...

    Cursor修改机器码

    "Cursor修改机器码"作为一个主题,可能指的是通过某种工具或脚本(如Cursor)来实现对机器码的修改。在全操作系统可用的语境下,这样的工具需要能够兼容不同的操作系统环境,如Windows、Linux和macOS等,并提供跨...

    cursor各个版本和续杯软件

    在信息技术领域,Cursor是一个软件名称,通常指代的是一种用于在计算机屏幕上移动和定位的设备,常被称为鼠标。然而,在此处的上下文中,Cursor似乎指代的是一款特定的软件,而非物理设备。根据给定的信息,Cursor...

    Cursor Setup 0.2.21-x64.exe

    Cursor 是一款基于 AI 技术的代码生成工具,它可以帮助开发人员自动生成代码,提高开发效率。 Cursor 是一款集成了 GPT-4 的免费 IDE 工具(目前免费),可以帮助用户快速编写、编辑和优化代码。 Cursor 是一款基于...

    Cursor-Setup-0.44.11-x64

    本案例中提到的软件Cursor,其版本0.45推出后,用户遇到了无法继续免费续费的问题,这可能是新版本中实施了新的收费策略或者是服务协议有所变更,导致原有的免费续费机制被移除。为了解决这一问题,部分用户选择了回...

    全新代码编辑器 Cursor window版本0.1.11

    Cursor Window是一款创新的代码编辑器,专为程序员和开发者设计,致力于提供高效、直观的代码编写体验。在0.1.11版本中,这款编辑器引入了一系列改进和功能,旨在提升开发者的生产力和舒适度。 首先,让我们深入...

    cursor 0.45.1版本

    cursor 0.45.1版本是一个特定的软件应用程序或功能更新,通常涉及到一种鼠标光标设计或软件工具,该工具可以在计算机操作系统中被安装以增强用户体验。在这个上下文中,cursor可能指的是一种光标修改工具,这类工具...

Global site tag (gtag.js) - Google Analytics