游标--cursor['kɜːsə]

  概念:

                        在执行SQL语句时,Oracle服务器将分配一个内存区域,不仅存储这个语句,还存储语句的结果 — 称为游标
  

 隐式游标
    DML语句或值返回一行结果的select语句时,Oracle服务器将创建一个隐式游标。
        隐式游标是自动的。

 
 显示游标
    select返回多行结果时,就必须创建一个显示游标   -   bulk collect 
    必须手工声明、打开和关闭
 
            cursor cursor_name is sql(sql指,sql语句)
 
      1.在进行任何处理前,必须首先打开游标:
         ---打开显示游标
             分配必要内存,执行select子句检索的数据加载到游标中
             open cursor_name;
             打开游标后,可以将游标中包含的数据赋给变量以进行处理
        
      2.从游标中提取数据:
         ----使用fetch命令来提取游标中的数据
             fetch命令提取数据后将值赋给变量
 
            fetch cursor_name into [v_name1,v_name2,………];
 
               %ROWCOUNT
                      -----处理的行数(DML执行后影响的行数)
                               sql%rowcount
                          cursor_name%rowcount
                 %FOUND
                          ----- 查找到了行
                %NOTFOUND
                           ------ 没查找到行
                sql%notfound
                          ------- cursor_name%notfound
                %ISOPEN
                          ------ 游标是否打开
 
 
      3.关闭游标
             必须明确关闭
             在可执行部分使用close命令
             close cursor_name;
 
实例一:
  1. declare
  2. v_no employee.empno%type;
  3. v_name employee.name%type;
  4. v_sal employee.salary%type;
  5. cursor emp_cursor isselect empno , name , salary
  6. from employee
  7. where empno ='0001';
  8. begin
  9. open emp_cursor;
  10. loop
  11. fetch emp_cursor into v_no,v_name,v_sal;
  12. exitwhen emp_cursor%notfound;
  13. dbms_output.put_line('编号'||v_no||'员工'||v_name||'的工资是'||v_sal);
  14. end loop;
  15. close emp_cursor;
  16. end;
 
 
游标for循环
              (自动open游标)
                     For name in cursorName loop  
                        ...  (处理sql语句)
                     end loop;
            (自动close游标)
实例二:
  1. declare
  2. cursor emps_cursor isselect*from employee order by empno;
  3. v_emp employee%rowtype;
  4. begin
  5. for v_emp in emps_cursor loop
  6. dbms_output.put_line('编号'||v_emp.empno||' 的员工: '||v_emp.name||' 的工资是 : '||v_emp.salary);
  7. end loop;
  8. end;
 
显式游标中:
      cursor_name%rowcount       -----游标推进行数
      cursor_name%found             -----fectch有没有找到找到一行
      cursor_name%notfound       -----fetch没有找到一行
ps:每fetch一次,游标自动推进一行
           %rowtype表示某个表的类型,类似某个表的一行,用来存放表中一行的数据
           游标能再次打开
 
实例三:
  1. declare
  2. cursor em_cursor isselect*from employee order by salary desc;
  3. v_emp employee%rowtype;
  4. begin
  5. open em_cursor;
  6. fetch em_cursor into v_emp;
  7. while em_cursor%rowcount<=5and em_cursor%found loop
  8. dbms_output.put_line(em_cursor%rowcount||''||v_emp.name||':'||v_emp.salary);
  9. fetch em_cursor into v_emp;
  10. end loop;
  11. close em_cursor;
  12. end;
 
课程作业:
  1. --查询所有学生及其专业信息-显示游标
  2. declare
  3. cursor stuMajors isselect s.stuNo, s.name, s.JavaSEScore, s.score, m.name as majorName
  4. from student s, major m
  5. where s.majorNo = m.majorNo;
  6. --定义变量与查询列一致
  7. v_stuNo student.stuNo%type;
  8. v_name student.name%type;
  9. v_seScore student.javasescore%type;
  10. v_sumscore student.score%type;
  11. v_majorName major.name%type;
  12. --记录
  13. type stumr is record(v_stuNo student.stuNo%type, v_name student.name%type,
  14. v_seScore student.javasescore%type, v_sumscore student.score%type,
  15. v_majorName major.name%type);
  16. stum stumr;
  17. begin
  18. open stuMajors;
  19. -- fetch stuMajors into stum;-- fetch 游标中查询的列应与变量记录中列保持一致
  20. -- dbms_output.put_line(stum.v_name);
  21. -- fetch stumajors into v_stuNo, v_name, v_seScore, v_sumscore, v_majorName;
  22. -- dbms_output.put_line(v_name || v_majorName);
  23. loop
  24. fetch stuMajors into stum;
  25. dbms_output.put_line(stum.v_stuNo ||' '|| stum.v_name ||' '|| stum.v_seScore ||' '||
  26. stum.v_sumScore ||' '|| stum.v_majorName );
  27. -- dbms_output.put_line(stuMajors%rowCount);
  28. exitwhen stuMajors%notFound;
  29. end loop;
  30. close stuMajors;
  31. --游标for循环
  32. end;
 
         
 
 

Cursor--游标的更多相关文章

  1. 【PLSQL】变量声明,结构语句,cursor游标

    ************************************************************************   ****原文:blog.csdn.net/clar ...

  2. cursor游标(mysql)

    /* 游标 cursor 什么是游标?为什么需要游标 使用存储过程对sql进行编程的时候,我们查询的语句可能是数据是多个,它总是一口气全部执行,我们无法针对每一条进行判断.也就是说,我们无法控制程序的 ...

  3. 转 oracle cursor 游标

    转自:http://blog.csdn.net/liyong199012/article/details/8948952 游标的概念:     游标是SQL的一个内存工作区,由系统或用户以变量的形式定 ...

  4. DRF url控制 解析器 响应器 版本控制 分页(常规分页,偏移分页,cursor游标分页)

    url控制 第二种写法(只要继承了ViewSetMixin) url(r'^pub/$',views.Pub.as_view({'get':'list','post':'create'})), #获取 ...

  5. SQL SERVER CURSOR游标的使用(转载)

    一:认识游标 游标(Cursor)它使用户可逐行访问由SQL Server返回的结果集. 使用游标(cursor)的一个主要的原因就是把集合操作转换成单个记录处理方式. 用SQL语言从数据库中检索数据 ...

  6. SQL Cursor 游标的使用

    DECLARE @name VARCHAR(50)  --声明游标 DECLARE cursor_VAA1 CURSOR FOR SELECT VAA05 FROM VAA1 --打开游标 OPEN ...

  7. SQL Cursor(游标)

    1.游标在数据表没有id(identity(1,1))时好用,但是游标会吃更多的内存,减少可用的并发,占用宽带,锁定资源,当然还有更多的代码量 2.如果能不用游标,尽量不要使用游标,用完用完之后一定要 ...

  8. 关键字(5):cursor游标:(循环操作批量数据)

    declare   cursor stus_cur is select * from students;  --定义游标并且赋值(is 不能和cursor分开使用)    cur_stu studen ...

  9. mysql cursor游标的使用,实例

    mysql被oracle收购后,从mysql-5.5开始,将InnoDB作为默认存储引擎,是一次比较重大的突破.InnoDB作为支持事务的存储引擎,拥有相关的RDBMS特性:包括ACID事务支持,数据 ...

  10. Sql Server - CURSOR (游标)

    1.声明游标            DECLARE 游标名 CURSOR SELECT语句(注:此处一定是SELECT语句)        2.打开游标           OPEN 游标名 3.读取 ...

随机推荐

  1. Android无法生成R文件的终极解决办法

    R文件如果在clean项目(Project—>Clean)和 Fix Project Properties(如下图):   如果在第一步无法解决的的时候,那可能原因就是资源文件调用的错误,比如资 ...

  2. java中的正则操作总结

    http://www.cnblogs.com/nerxious/archive/2013/01/03/2842910.html 正则表达式在处理字符串的效率上是相当高的 关于正则表达式的使用,更多的是 ...

  3. Android中通过WebView控件实现与JavaScript方法相互调用的地图应用

    在Android中通过WebView控件,可以实现要加载的页面与Android方法相互调用,我们要实现WebView中的addJavascriptInterface方法,这样html才能调用andro ...

  4. python源码解析

    http://blog.csdn.net/balabalamerobert/article/category/168910

  5. Opacity多浏览器透明度兼容处理(转)

    用来设定元素透明度的 Opacity 是CSS 3里的一个属性.当然现在还只有少部分浏览器支持. 不过各个浏览器都有自己的私有属性来支持,其中包括老版本的Mozilla和Safari: IE: fil ...

  6. 利用 Composer 一步一步构建自己的 PHP 框架(一)——基础准备

    『Composer 一统天下的时代已经到来!』——白岩松 “一个时代结束了,另一个时代开始了.” Framework Interoperability Group(框架可互用性小组),简称 FIG,成 ...

  7. 给jdk写注释系列之jdk1.6容器(2)-LinkedList源码解析

    LinkedList是基于链表结构的一种List,在分析LinkedList源码前有必要对链表结构进行说明.   1.链表的概念      链表是由一系列非连续的节点组成的存储结构,简单分下类的话,链 ...

  8. 关于在Eclipse中构建patch开发环境

    git仓库中不能添加空文件夹. 至于为什么git 仓库中不能添加空文件夹,我没有找到具体的原因. 在V2EX上有人说: 我猜是因为git的内部实现,即只对文件做快照决定的吧,另一方面空文件夹确实对源代 ...

  9. hdu1560 搜索

    从原串的最大长度开始枚举,当某个长度的值能保存所有串时,即成功.对每个长度进行深搜,每次取某个串的第一个. #include<iostream> #include<cstdio> ...

  10. CF 19D - Points 线段树套平衡树

    题目在这: 给出三种操作: 1.增加点(x,y) 2.删除点(x,y) 3.询问在点(x,y)右上方的点,如果有相同,输出最左边的,如果还有相同,输出最低的那个点 分析: 线段树套平衡树. 我们先离散 ...