当前位置:  数据库>oracle

Oracle游标的使用方法

    来源: 互联网  发布时间:2017-06-24

    本文导语: Oracle游标的使用方法 -- 声明游标;CURSOR cursor_name IS select_statement --For 循环游标--(1)定义游标--(2)定义游标变量--(3)使用for循环来使用这个游标declare      --类型定义      cursor c_job      is      select empno,ename,job,sal  ...

Oracle游标的使用方法

-- 声明游标;CURSOR cursor_name IS select_statement

--For 循环游标
--(1)定义游标
--(2)定义游标变量
--(3)使用for循环来使用这个游标
declare
      --类型定义
      cursor c_job
      is
      select empno,ename,job,sal
      from emp
      where job='MANAGER';
      --定义一个游标变量v_cinfo c_emp%ROWTYPE ,该类型为游标c_emp中的一行数据类型
      c_row c_job%rowtype;
begin
      for c_row in c_job loop
        dbms_output.put_line(c_row.empno||'-'||c_row.ename||'-'||c_row.job||'-'||c_row.sal);
      end loop;
end;


     
--Fetch游标
--使用的时候必须要明确的打开和关闭

declare
      --类型定义
      cursor c_job
      is
      select empno,ename,job,sal
      from emp
      where job='MANAGER';
      --定义一个游标变量
      c_row c_job%rowtype;
begin
      open c_job;
        loop
          --提取一行数据到c_row
          fetch c_job into c_row;
          --判读是否提取到值,没取到值就退出
          --取到值c_job%notfound 是false
          --取不到值c_job%notfound 是true
          exit when c_job%notfound;
            dbms_output.put_line(c_row.empno||'-'||c_row.ename||'-'||c_row.job||'-'||c_row.sal);
        end loop;
      --关闭游标
      close c_job;
end;

--1:任意执行一个update操作,用隐式游标sql的属性%found,%notfound,%rowcount,%isopen观察update语句的执行情况。
      begin
        update emp set ENAME='ALEARK' WHERE EMPNO=7469;
        if sql%isopen then
          dbms_output.put_line('Openging');
          else
            dbms_output.put_line('closing');
            end if;
          if sql%found then
            dbms_output.put_line('游标指向了有效行');--判断游标是否指向有效行
            else
              dbms_output.put_line('Sorry');
              end if;
              if sql%notfound then
                dbms_output.put_line('Also Sorry');
                else
                  dbms_output.put_line('Haha');
                  end if;
                  dbms_output.put_line(sql%rowcount);
                  exception
                    when no_data_found then
                      dbms_output.put_line('Sorry No data');
                      when too_many_rows then
                        dbms_output.put_line('Too Many rows');
                        end;
declare
      empNumber emp.EMPNO%TYPE;
      empName emp.ENAME%TYPE;
      begin
        if sql%isopen then
          dbms_output.put_line('Cursor is opinging');
          else
            dbms_output.put_line('Cursor is Close');
            end if;
            if sql%notfound then
              dbms_output.put_line('No Value');
              else
                dbms_output.put_line(empNumber);
                end if;
                dbms_output.put_line(sql%rowcount);
                dbms_output.put_line('-------------');
               
                select EMPNO,ENAME into  empNumber,empName from emp where EMPNO=7499;
                dbms_output.put_line(sql%rowcount);
               
                if sql%isopen then
                dbms_output.put_line('Cursor is opinging');
                else
                dbms_output.put_line('Cursor is Closing');
                end if;
                if sql%notfound then
                dbms_output.put_line('No Value');
                else
                dbms_output.put_line(empNumber);
                end if;
                exception
                  when no_data_found then
                    dbms_output.put_line('No Value');
                    when too_many_rows then
                      dbms_output.put_line('too many rows');
                      end;
                 
               
     
--2,使用游标和loop循环来显示所有部门的名称
--游标声明
declare
      cursor csr_dept
      is
      --select语句
      select DNAME
      from Depth;
      --指定行指针,这句话应该是指定和csr_dept行类型相同的变量
      row_dept csr_dept%rowtype;
begin
      --for循环
      for row_dept in csr_dept loop
          dbms_output.put_line('部门名称:'||row_dept.DNAME);
      end loop;
end;


--3,使用游标和while循环来显示所有部门的的地理位置(用%found属性)
declare
      --游标声明
      cursor csr_TestWhile
      is
      --select语句
      select  LOC
      from Depth;
      --指定行指针
      row_loc csr_TestWhile%rowtype;
begin
  --打开游标
      open csr_TestWhile;
      --给第一行喂数据
      fetch csr_TestWhile into row_loc;
      --测试是否有数据,并执行循环
        while csr_TestWhile%found loop
          dbms_output.put_line('部门地点:'||row_loc.LOC);
          --给下一行喂数据
          fetch csr_TestWhile into row_loc;
        end loop;
      close csr_TestWhile;
end;
select * from emp

 

     
--4,接收用户输入的部门编号,用for循环和游标,打印出此部门的所有雇员的所有信息(使用循环游标)
--CURSOR cursor_name[(parameter[,parameter],...)] IS select_statement;
--定义参数的语法如下:Parameter_name [IN] data_type[{:=|DEFAULT} value] 

declare
      CURSOR
      c_dept(p_deptNo number)
      is
      select * from emp where emp.depno=p_deptNo;
      r_emp emp%rowtype;
begin
        for r_emp in c_dept(20) loop
            dbms_output.put_line('员工号:'||r_emp.EMPNO||'员工名:'||r_emp.ENAME||'工资:'||r_emp.SAL);
        end loop;
end;
select * from emp 
--5:向游标传递一个工种,显示此工种的所有雇员的所有信息(使用参数游标)
declare
      cursor
      c_job(p_job nvarchar2)
      is
      select * from emp where JOB=p_job;
      r_job emp%rowtype;
begin
      for r_job in c_job('CLERK') loop
          dbms_output.put_line('员工号'||r_job.EMPNO||' '||'员工姓名'||r_job.ENAME);
        end loop;
end;
SELECT * FROM EMP

--6:用更新游标来为雇员加佣金:(用if实现,创建一个与emp表一摸一样的emp1表,对emp1表进行修改操作),并将更新前后的数据输出出来
--http://zheng12tian.iteye.com/blog/815770
        create table emp1 as select * from emp;
       
declare
        cursor
        csr_Update
        is
        select * from  emp1 for update OF SAL;
        empInfo csr_Update%rowtype;
        saleInfo  emp1.SAL%TYPE;
begin
    FOR empInfo IN csr_Update LOOP
      IF empInfo.SALr_testAvg.DEP_AVG then
    salInfo:=r_testAvg.SAL-50;
    end if;
    update emp1 set SAL=salInfo where current of crs_testAvg;
    end loop;
end;


    
 
 

您可能感兴趣的文章:

  • oracle的最大游标数问题
  • Oracle事务!使用游标提交过程
  • Oracle 数据 使用游标
  • 关于Oracle游标的问题(ORA-01000: maximum open cursors exceeded)
  • jsp访问oracle超出打开游标的最大数是什么原因?急,在线给分。
  • 在Oracle PL/SQL中游标声明中表名动态变化的方法
  • oracle 声明游标(不具备字段)规则应用
  • Oracle存储过程返回游标实例详解
  • oracle 在一个存储过程中调用另一个返回游标的存储过程
  • Oracle 游标使用总结
  • linux下安装oracle后使用命令行启动的方法 linux启动oracle
  • oracle中UPDATE nowait 的使用方法介绍
  • oracle10g全文索引自动同步语句使用方法
  • Linux下Oracle的sqlplus使用光标上下左右方法
  • oracle关键字作为字段名使用方法
  • c#中oracle的to_date函数使用方法
  • oracle使用instr或like方法判断是否包含字符串
  • SQL Server中使用Linkserver连接Oracle的方法
  • oracle数据库导入导出命令使用方法
  • oracle冷备份恢复和oracle异机恢复使用方法
  • 使用Oracle数据挖掘API方法详解[图文]
  • oracle trunc()函数的使用方法
  • oracle11gR2使用exp导出命令时报EXP-00011错误的解决方法
  • oracle中decode函数的使用方法
  • [Oracle] dbms_metadata.get_ddl 的使用方法总结
  • 关于Oracle数据库中快照的使用方法介绍
  • Oracle中instr函数使用方法
  • Oracle 分析函数RANK(),ROW_NUMBER(),LAG()等的使用方法
  • oracle 使用sql获取数据库表、表的字段的多种方法
  • oracle排名函数的使用方法分享
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • ORACLE 中修改用户密码的方法
  • Linux下完全卸载ORACLE 10G的方法
  • 将Oracle 8i数据成功移植Oracle 10g的方法
  • Oracle Connect to Idle Instance解决方法
  • oracle增加表空间大小两种实现方法
  • linux下用ODBC链接Oracle怎么连啊?跪求具体方法!!!
  • Linux系统下查看oracle SID的方法
  • oracle 彻底删除方法
  • window中oracle环境变量设置方法分享
  • Oracle 忘记密码的找回方法
  • oracle的job不能运行问题的解决方法
  • Linux下Oracle 10G DBCA等汉字乱码解决方法
  • Oracle中serveroutput参数一次设置永久保存方法
  • Oracle指定IP访问数据库方法
  • Oracle SID存在解決方法
  • 登录oracle数据库时密码忘记的解决方法
  • PB7 连接 Oracle 的设置方法
  • Oracle删除后不能重新安装的解决方法
  • oracle删除文件后数据库启动不了的处理方法
  • 跪求UNIX 下C用OCI连接ORACLE方法。高手进!!!
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3