1. % type 用法,提取% type所在字段的类型

declare
    myid dept.deptno % type;
    myname dept.dname % type;
begin
    select deptno, dname into myid, myname from dept where deptno = 10;
    dbms_output.put_line(myid);
    dbms_output.put_line(myname);
end;2. % rowtype 用法,提取% rowtype所在字段的类型

declare
    type type_dept is table of dept % rowtype index by binary_integer;
    tb type_dept;
begin
    tb(1).deptno:='001';
    tb(2).deptno:='002';
    dbms_output.put_line(tb.COUNT);
end;
/3. TYPE用法,相当于结构体

declare
    lv_order_date DATE:=sysdate;
    lv_last_tr varchar2(5) default '001';
    lv_last varchar2(10) not null:='us';
    TYPE type_test is record(
        myid dept.deptno % type,
        myname dept.dname % type
    );
    rec type_test;
begin
    dbms_output.put_line(lv_last);
    select deptno, dname into rec from dept where deptno=10;
    dbms_output.put_line(rec.myid);
    dbms_output.put_line(rec.myname);
end;
/4. 游标的使用

declare
    g_id number(2) := 20;
    find_not char(1) := 'N';
    cursor cur is select * from dept;
    TYPE type_dept is record(
        myid dept.deptno % type,
        myname dept.dname % type,
        myaddr dept.loc % type
    );
    rect type_dept;
begin
    open cur;
    loop
        fetch cur into rect;
        exit when cur%     NOTFOUND;
        if rect.myid = g_id then
            dbms_output.put_line('Find it!!');
            dbms_output.put_line('DEPT NO: ' || rect.myid);
            dbms_output.put_line('DNAME: ' || rect.myname);
            dbms_output.put_line('LOC: ' || rect.myaddr);
        end if;
    end loop;
    close cur;
   
    if find_not = 'N' then
        dbms_output.put_line('No Record');
    end if;
end;
/5. for循环

begin
    for i in 1..5 loop
        dbms_output.put_line(i);
    end loop;
end;
/6. loop循环

declare
    v number := 1;
begin
    loop
        exit when v > 5;
        dbms_output.put_line(v);
        v := v+1;
    end loop;
end;
/ 7. while循环

declare
    v number := 1;
begin
    while v <= 5 loop
        dbms_output.put_line(v);
        v := v+1;
    end loop;
end;
/

OCM读书笔记(2) - PL/SQL 基础的更多相关文章

  1. 《玩转Django2.0》读书笔记-Django建站基础

    <玩转Django2.0>读书笔记-Django建站基础 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.网站的定义及组成 网站(Website)是指在因特网上根据一 ...

  2. 《Essential C++》读书笔记 之 C++编程基础

    <Essential C++>读书笔记 之 C++编程基础 2014-07-03 1.1 如何撰写C++程序 头文件 命名空间 1.2 对象的定义与初始化 1.3 撰写表达式 运算符的优先 ...

  3. Oracle实战笔记(第六天)之PL/SQL基础

    一.PL/SQL介绍 1.概念 PL/SQL也是一种程序语言,叫做过程化SQL语言(Procedural Language/SQL).PL/SQL是Oracle数据库对SQL语句的扩展.在普通SQL语 ...

  4. PL/SQL基础2(笔记)

    1 第一个PL/SQL的程序 DECLARE BEGIN DBMS_OUTPUT.PUT_LINE('Hello World!'); END; / --2一个简单的PL/SQL程序 DECLARE v ...

  5. PL/SQL基础1(笔记)

    --基本结构DECLARE--变量声明部分:在此声明PL/SQL用到的变量,类型,游标,以及局部的存储过程和函数BEGIN --执行部分:过程及SQL语句,即程序的主要部分 EXCEPTION --执 ...

  6. 慕课网笔记之oracle开发利器-PL/SQL基础

    实例1--if语句 /* 慕课网Oracle数据库开发必备之PL/SQL_2-3 判断用户从键盘输入的数字 1.如何使用if语句 2.接收一个键盘的输入(字符串) */ set serveroutpu ...

  7. Oracle442个应用场景---------PL/SQL基础

    ----------------------------------------------------------------------------------- 备份和恢复数据库略过.在后面解说 ...

  8. Oracle数据库之PL/SQL基础

    介绍PL/SQL之前,先介绍一个图像化工具:Oracle SQL Developer 在oracle的开发过程中, 我们难免会使用第三方开发的软件来辅助我们书写SQL, pl/sql是一个不错的sql ...

  9. PL SQL 基础

    Oracle之PL/SQL学习笔记   自己在学习Oracle是做的笔记及实验代码记录,内容挺全的,也挺详细,发篇博文分享给需要的朋友,共有1w多字的学习笔记吧.是以前做的,一直在压箱底,今天拿出来整 ...

随机推荐

  1. zoj 2277 The Gate to Freedom

    N^N = X --->    Nlog10(N) = log10( X ) ---->    X的最高位为 Nlog10(N) 小数部分的第一个非0位 #include<stdio ...

  2. SQL基础使用

    result = executeQuery(“ SELECT FName, FSalary FROM T_Employee ”); for(i=0;i<result.count;i++) { s ...

  3. 离散傅立叶变换与快速傅立叶变换(DFT与FFT)

    自从去年下半年接触三维重构以来,听得最多的词就是傅立叶变换,后来了解到这个变换在图像处理里面也是重点中的重点. 本身自己基于高数知识的理解是傅立叶变换是将一个函数变为一堆正余弦函数的和的变换.而图像处 ...

  4. 【转】增强 scite 编辑器的代码提示功能

    在 windows 下写 Lua, 我能找到的最好的编辑器就是 luaForWindows 项目里带的 scite. npp (即 notepad++ ) 也将就着能用, 不过只有代码高亮和简单的单词 ...

  5. java--进步学习IO

    import java.io.*; public class Demo1 { public static void main(String []args) throws Exception{ File ...

  6. QTableWidget 导出到csv表格

    跳槽到了新的公司,开始苦逼的出差现场开发,接触到了新的应用.有很多应用需要将Table导出成表格,可以把table导出成csv格式的文件.跟大伙分享一下: lass TableToExcle : pu ...

  7. Mixtile LOFT

    日前,国内电子原型类开发团队Mixtile(深圳致趣科技)新推出的 Mixtile LOFT套件,受到业内著名的海外科技网站CNXSoft的关注和报道. 如果要阅读相关的原文报道,可点击这里.下面摘录 ...

  8. 王立平-- ContentValues , HashTable , HashMap差别

    ContentValues  :是一种存储机制,key-value 特点:key仅仅能是string类型.value:仅仅能是基本类型,不能是对象. 应用:经常使用语往数据库中插入数据 Content ...

  9. cocos2dx-lua捕获用户touch事件的几种方式

    这里仅仅针对lua 1.为每一个关心的事件注冊回调函数 详细分为下面几种 1>单点触摸 注冊函数为 cc.Handler.EVENT_TOUCH_BEGAN      = 40 cc.Handl ...

  10. jQuery操作checkbox的问题

    问题: 使用 jquery 的 attr('checked',false) 和 attr('checked',true) 方法给 checkbox 设置选中和未选中状态时,失效. 原因: jquery ...