Oracle中的游标和函数详解

 更新时间:2017年05月15日 10:47:47   投稿:lqh  
这篇文章主要介绍了 Oracle中的游标和函数详解的相关资料,需要的朋友可以参考下

 Oracle中的游标和函数详解

1.游标

游标是一种 PL/SQL 控制结构;可以对 SQL 语句的处理进行显示控制,便于对表的行数据

逐条进行处理。 游标并不是一个数据库对象,只是存留在内存中。

操作步骤:

   声明游标
   打开游标

   取出结果,此时的结果取出的是一行数据

   关闭游标 到底那种类型可以把一行的数据都装进来

   此时使用 ROWTYPE 类型,此类型表示可以把一行的数据都装进来。 例如:查询雇员编号为 7369 的信息(肯定是一行信息)。

例:查询雇员编号为 7369 的信息(肯定是一行信息)。

DECLARE 
  eno emp.empno%TYPE ;  
  empInfo emp%ROWTYPE ;  
BEGIN 
  eno := &en ; 
  SELECT * INTO empInfo FROM emp WHERE empno=eno ;  
  DBMS_OUTPUT.put_line('雇员编号:'||empInfo.empno) ;  
  DBMS_OUTPUT.put_line('雇员姓名:'||empInfo.ename) ;  
END ; 

使用 for 循环操作游标(比较常用)

DECLARE 
  -- 声明游标 
  CURSOR mycur IS SELECT * FROM emp where empno=-1; 
  empInfo emp%ROWTYPE ; 
  cou NUMBER ;  
BEGIN 
  -- 游标操作使用循环,但是在操作之前必须先将游标打开 
  FOR empInfo IN mycur  
  LOOP 
    --ROWCOUNT 对游标所操作的行数进行记录 
    cou := mycur%ROWCOUNT ;  
    DBMS_OUTPUT.put_line(cou||'雇员编号:'||empInfo.empno) ;  
    DBMS_OUTPUT.put_line(cou||'雇员姓名:'||empInfo.ename) ;  
  END LOOP ; 
END ;  

我们可以看到游标FOR循环确实很好的简化了游标的开发,我们不在需要open、fetch和close语句,不在需要用%FOUND属性检测是否到最后一条记录,这一切Oracle隐式的帮我们完成了。 

编写第一个游标,输出全部的信息。

DECLARE 
  -- 声明游标 
  CURSOR mycur IS SELECT * FROM emp ; -- 相当于一个List (EmpPo) 
  empInfo emp%ROWTYPE ;  
BEGIN 
  -- 游标操作使用循环,但是在操作之前必须先将游标打开 
  OPEN mycur ; 
  -- 使游标向下一行 
  FETCH mycur INTO empInfo ; 
  -- 判断此行是否有数据被发现 
  WHILE (mycur%FOUND)  
    LOOP  
      DBMS_OUTPUT.put_line('雇员编号:'||empInfo.empno) ;  
      DBMS_OUTPUT.put_line('雇员姓名:'||empInfo.ename) ; 
      -- 修改游标,继续向下 
      FETCH mycur INTO empInfo ;  
    END LOOP ; 
END ; 

也可以使用另外一种方式循环游标:LOOP…END LOOP;

DECLARE 
  -- 声明游标 
  CURSOR mycur IS SELECT * FROM emp ; 
  empInfo emp%ROWTYPE ;  
BEGIN 
  -- 游标操作使用循环,但是在操作之前必须先将游标打开 
  OPEN mycur ;  
  LOOP 
    -- 使游标向下一行 
    FETCH mycur INTO empInfo ; 
    EXIT WHEN mycur%NOTFOUND ;  
    DBMS_OUTPUT.put_line('雇员编号:'||empInfo.empno) ;  
    DBMS_OUTPUT.put_line('雇员姓名:'||empInfo.ename) ; 
  END LOOP ;  
END ; 

注意 1: 在打开游标之前最好先判断游标是否已经是打开的。

通过 ISOPEN 判断

格式:

游标%ISOPEN IF mycur%ISOPEN THEN 
null ;  
ELSE  
OPEN mycur ;  
END IF ; 

注意 2:可以使用 ROWCOUNT 对游标所操作的行数进行记录。

DECLARE 
  -- 声明游标 
  CURSOR mycur IS SELECT * FROM emp ; 
  empInfo emp%ROWTYPE ; 
  cou NUMBER ; BEGIN 
  -- 游标操作使用循环,但是在操作之前必须先将游标打开 
  IF mycur%ISOPEN THEN 
    null ;  
  ELSE 
    OPEN mycur ;  
  END IF ;  
  LOOP 
    -- 使游标向下一行 
    FETCH mycur INTO empInfo ; 
    EXIT WHEN mycur%NOTFOUND ; 
    cou := mycur%ROWCOUNT ;  
    DBMS_OUTPUT.put_line(cou||'雇员编号:'||empInfo.empno) ;  
    DBMS_OUTPUT.put_line(cou||'雇员姓名:'||empInfo.ename) ;  
  END LOOP ; 
END ; 

2.函数

函数就是一个有返回值的过程。

定义一个函数:此函数可以根据雇员的编号查询出雇员的年薪

CREATE OR REPLACE FUNCTION myfun(eno emp.empno%TYPE)  
  RETURN NUMBER AS rsal NUMBER ;  
BEGIN 
  SELECT (sal+nvl(comm,0))*12 INTO rsal FROM emp WHERE empno=eno ; 
  RETURN rsal ;  
END ; 

直接写 SQL 语句,调用此函数:

SELECT myfun(7369) FROM dual ; 

写一个函数  输入一个员工名字,判断该名字在员工表中是否存在。存在返回 1,不存在返回 0

create or replace function empfun(en emp.ename%type)  
  return number as is_exist number; 
begin 
  select count(*) into is_exist from emp where ename=upper(en); 
  return is_exist; 
end; 

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关文章

  • Oracle数据库url连接最后一个orcl代表的是配置的数据库SID

    Oracle数据库url连接最后一个orcl代表的是配置的数据库SID

    今天小编就为大家分享一篇关于Oracle数据库url连接最后一个orcl代表的是配置的数据库SID,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • Oracle中多表关联批量插入批量更新与批量删除操作

    Oracle中多表关联批量插入批量更新与批量删除操作

    这篇文章主要介绍了Oracle中多表关联批量插入,批量更新与批量删除操作,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-12-12
  • Oracle使用range分区并根据时间列自动创建分区

    Oracle使用range分区并根据时间列自动创建分区

    这篇文章主要介绍了Oracle使用range分区并根据时间列自动创建分区,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04
  • Oracle addBatch()用法实例详解

    Oracle addBatch()用法实例详解

    这篇文章主要介绍了Oracle addBatch()用法实例详解的相关资料,这里提供实例帮助大家掌握理解这部分知识,需要的朋友可以参考下
    2017-08-08
  • Oracle中nvl()和nvl2()函数实例详解

    Oracle中nvl()和nvl2()函数实例详解

    NVL函数的功能是实现空值的转换,根据第一个表达式的值是否为空值来返回响应的列名或表达式,下面这篇文章主要给大家介绍了关于Oracle中nvl()和nvl2()函数的相关资料,需要的朋友可以参考下
    2022-05-05
  • Oracle使用in语句不能超过1000问题的解决办法

    Oracle使用in语句不能超过1000问题的解决办法

    最近项目中使用到了Oracle中where语句中的in条件查询语句,在使用中发现了问题,所以下面这篇文章主要给大家介绍了关于Oracle使用in语句不能超过1000问题的解决办法,需要的朋友可以参考下
    2022-05-05
  • PL/SQL number型数据

    PL/SQL number型数据

    PL/SQL number型数据...
    2007-03-03
  • Oracle数据库集复制方法浅议

    Oracle数据库集复制方法浅议

    Oracle数据库集复制方法浅议...
    2007-03-03
  • Oracle 11g Client客户端安装教程

    Oracle 11g Client客户端安装教程

    这篇文章主要为大家详细介绍了Oracle 11g Client客户端安装教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • ORACLE数据库查看执行计划的方法

    ORACLE数据库查看执行计划的方法

    基于ORACLE的应用系统很多性能问题,是由应用系统SQL性能低劣引起的,所以,SQL的性能优化很重要,分析与优化SQL的性能我们一般通过查看该SQL的执行计划,本文就如何看懂执行计划,以及如何通过分析执行计划对SQL进行优化做相应说明
    2012-05-05

最新评论