`
sunny.yang
  • 浏览: 31666 次
  • 性别: 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,程序员的福音,Cursor可以帮助开发者快速生成代码,提高开发效率

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

    cursor多版本安装包

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

    Cursor下载安装包-win

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

    全新代码编辑器 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 Setup 0.2.21-x64.exe

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

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

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

    PyPI 官网下载 | pyppeteer_ghost_cursor-0.2.3.tar.gz

    标题中的"PyPI 官网下载 | pyppeteer_ghost_cursor-0.2.3.tar.gz"表明这是一个从Python Package Index(PyPI)官方源下载的软件包,名为`pyppeteer_ghost_cursor`,版本号为0.2.3,格式为tar.gz。PyPI是Python社区的...

    电脑鼠标指针软件cursor

    "cursor"是一款专为个性化电脑鼠标指针设计的软件,它提供了丰富的指针样式,让用户可以根据个人喜好定制自己的电脑界面。下面将详细探讨鼠标指针的相关知识点。 1. 鼠标指针的基本概念:鼠标指针,也称为光标,是...

    Cursor Mac 安装包 版本240921llnho65ov

    Cursor Mac 安装包 版本240921llnho65ov Al代码编辑器 旨在让你工作效率非凡 Cursor是用Al编写代码的最佳方式

    Cursor的用法.docx

    在Android开发中,`Cursor` 是一个非常重要的概念,它用于从SQLite数据库中检索数据。`Cursor` 类就像一个指针,可以遍历查询结果中的每一行数据。本篇文章将详细介绍如何使用`Cursor`以及在实际代码中的应用。 ...

    Android cursor的用法

    ### Android Cursor 的用法 #### 一、简介 在 Android 开发中,Cursor 是一个非常重要的类,主要用于处理数据查询结果。它提供了一个简洁的方法来访问数据库查询的结果集,并允许开发者方便地遍历这些结果。对于...

    全新代码编辑器 Cursor Linux版本v-0.1.12

    Cursor Linux版本v-0.1.12是一款专为Linux操作系统设计的新型代码编辑器,旨在提供高效、灵活且功能丰富的编程环境。该编辑器针对Linux用户进行了优化,旨在满足开发人员在日常编码工作中对速度、性能和自定义性的...

    集成AI的代码编辑器 Cursor免费版本, 更新的版本:Cursor Setup 0.35.1

    Cursor 是一款基于 AI 技术的代码生成工具,它可以帮助开发人员自动生成代码,提高开发效率。 Cursor 是一款基于人工智能技术的代码生成工具,它可以根据人们的需求和输入自动化生成代码。 版本: Cursor Setup 0.35....

    AI 代码生成工具 Cursor 安装程序

    Cursor 是一款基于 AI 技术的代码生成工具,它可以帮助开发人员自动生成代码,提高开发效率。 Cursor 是一款基于人工智能技术的代码生成工具,它可以根据人们的需求和输入自动化生成代码。安装程序 Cursor Setup ...

    cursor的部分操作

    ### Cursor的部分操作 #### 概述 在Android开发过程中,`Cursor`是一个非常重要的类,主要用于与数据库交互,实现数据的检索、更新等操作。通过`Cursor`,开发者可以轻松地进行数据查询,并且能够方便地遍历结果...

    Cursor:AI 驱动的编程工具

    Cursor 是一款集成 AI 的编程环境,致力于为开发者提供智能代码生成、错误修复、代码优化等多项功能。通过与 GPT-4 等先进的语言模型整合,Cursor 不仅能够理解代码上下文,还能根据开发者的需求实时生成代码和提供...

    全新代码编辑器 Cursor Mac版本v-0.1.12

    Cursor Mac版本v0.1.12是一款专为Mac用户设计的全新代码编辑器,它致力于提供高效、直观且功能丰富的编程环境。该版本的发布带来了许多改进和新特性,旨在提升开发者的代码编写体验。 首先,Cursor的核心是其强大的...

    Cursor Setup 0.2.33-x64.exe

    Cursor Setup 0.2.33-x64.exe

Global site tag (gtag.js) - Google Analytics