zoukankan      html  css  js  c++  java
  • Oracle Sql 语法收集.

    一.Oracle的Cursors概念:
    游标:用来查询数据库,获取记录集合(结果集)的指针,可以让开发者一次访问一行结果集,在每条结果集上作操作。

    二.Oracle的Cursors分类:
    1.静态游标:
    分为显式游标和隐式游标。
    2.REF游标:
    是一种引用类型,类似于指针。

    三.Oracle的Cursors详细内容:
    1.显式游标:
    CURSOR游标名(参数) [返回值类型] IS
    Select语句
    生命周期:
    a.打开游标(OPEN)
    解析,绑定。。。不会从数据库检索数据
    b.从游标中获取记录(FETCH INTO)
    执行查询,返回结果集。通常定义局域变量作为从游标获取数据的缓冲区。
    c.关闭游标(CLOSE)
    完成游标处理,用户不能从游标中获取行。还可以重新打开。
    选项:参数和返回类型
    set serveroutput on
    declare
    cursor emp_cur ( p_deptid in number) is
    select * from employees where department_id = p_deptid;
    l_emp employees%rowtype;
    begin
    dbms_output.put_line('Getting employees from department 30');
    open emp_cur(30);
    loop
      fetch emp_cur into l_emp;
      exit when emp_cur%notfound;
      dbms_output.put_line('Employee id '|| l_emp.employee_id || ' is ');
      dbms_output.put_line(l_emp.first_name || ' ' || l_emp.last_name);
    end loop;
    close emp_cur;
    dbms_output.put_line('Getting employees from department 90');
    open emp_cur(90);
    loop
      fetch emp_cur into l_emp;
      exit when emp_cur%notfound;
      dbms_output.put_line('Employee id '|| l_emp.employee_id || ' is ');
      dbms_output.put_line(l_emp.first_name || ' ' || l_emp.last_name);
    end loop;
    close emp_cur;
    end;
    /

    2.隐式游标:
    不用明确建立游标变量,分两种:
    a.在PL/SQL中使用DML语言,使用ORACLE提供的名为SQL的隐示游标
    b.CURSOR FOR LOOP,用于for loop语句
    a.举例:
    declare
    begin
    update departments set department_name=department_name;
    --where 1=2;

    dbms_output.put_line('update '|| sql%rowcount ||' records');
    end;
    /

    b.举例:
    declare
    begin
    for my_dept_rec in ( select department_name, department_id from departments)
    loop
      dbms_output.put_line(my_dept_rec.department_id || ' : ' || my_dept_rec.department_name);
    end loop;
    end;
    /

    c.举例:
    单独select
    declare
    l_empno emp.EMPLOYEE_ID%type;
    -- l_ename emp.ename%type;
    begin
    select EMPLOYEE_ID  
      into l_empno
    from emp;
    --where rownum =1;
    dbms_output.put_line(l_empno);
    end;
    /

    使用INTO获取值,只能返回一行。

    游标属性:
    %FOUND:变量最后从游标中获取记录的时候,在结果集中找到了记录。
    %NOTFOUND:变量最后从游标中获取记录的时候,在结果集中没有找到记录。
    %ROWCOUNT:当前时刻已经从游标中获取的记录数量。
    %ISOPEN:是否打开。
    Declare
    Cursor emps is
    Select * from employees where rownum<6 order by 1;

    Emp employees%rowtype;
    Row number :=1;
    Begin
    Open emps;
    Fetch emps into emp;

    Loop
      If emps%found then
       Dbms_output.put_line('Looping over record '||row|| ' of ' || emps%rowcount);
       Fetch emps into emp;
       Row := row + 1;
      Elsif emps%notfound then
       Exit;  ---exit loop, not IF
      End if;
    End loop;

    If emps%isopen then
      Close emps;
    End if;
    End;
    /

    显式和隐式游标的区别:
    尽量使用隐式游标,避免编写附加的游标控制代码(声明,打开,获取,关闭),也不需要声明变量来保存从游标中获取的数据。

    3.REF CURSOR游标:
    动态游标,在运行的时候才能确定游标使用的查询。分类:
    1.强类型(限制)REF CURSOR,规定返回类型
    2.弱类型(非限制)REF CURSOR,不规定返回类型,可以获取任何结果集。
    TYPE ref_cursor_name IS REF CURSOR [RETURN return_type]

    Declare
    Type refcur_t is ref cursor;

    Type emp_refcur_t is ref cursor return employee%rowtype;
    Begin
    Null;
    End;
    /

    强类型举例:
    declare
    --声明记录类型
    type emp_job_rec is record(
      employee_id number,
      employee_name varchar2(50),
      job_title varchar2(30)
    );
    --声明REF CURSOR,返回值为该记录类型
    type emp_job_refcur_type is ref cursor
      return emp_job_rec;
    --定义REF CURSOR游标的变量
    emp_refcur emp_job_refcur_type;
    emp_job emp_job_rec;
    begin
    open emp_refcur for
      select e.employee_id,
        e.first_name || ' ' ||e.last_name "employee_name",
        j.job_title
      from employees e, jobs j
      where e.job_id = j.job_id and rownum < 11 order by 1;
    fetch emp_refcur into emp_job;
    while emp_refcur%found loop
      dbms_output.put_line(emp_job.employee_name || '''s job is ');
      dbms_output.put_line(emp_job.job_title);
      fetch emp_refcur into emp_job;
    end loop;
    end;
    /


    本篇文章来源于 PHP资讯 原文链接:http://www.phpq.net/oracle/oracle-cursors-syntax.html

  • 相关阅读:
    python -- 内存与垃圾回收源码分析
    机器学习:决策树
    leetcode -- 树操作
    树:基本树形
    树:遍历算法
    查找:字符串匹配算法 -- KMP
    Java 8 新特性
    Java学习书籍推荐
    Guava基本工具--Throwables:简化异常和错误的传播与检查
    Guava基本工具--排序: Guava强大的”流畅风格比较器”
  • 原文地址:https://www.cnblogs.com/soundcode/p/1924363.html
Copyright © 2011-2022 走看看