`
流浪鱼
  • 浏览: 1693867 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

PL/SQL入门教程

 
阅读更多

PL/SQL入门教程

1.1 PL/SQL简介
1.2 创建PL/SQL程序块
1.3 PL/SQL数据类型
1.4 处理PL/SQL的异常
     1.4.1 PL/SQL的异常
     1.4.2 自定义异常处理
      1.4.3 自定义异常
1.5 在PL/SQL中单条记录的查询
1.6 用光标查询多条记录
     1.6.1 使用光标的基本方法
     1.6.2 使用光标FOR循环
     1.6.3 带参数的光标
1.7 创建代表数据库记录和列的变量
1.8 怎样用PL/SQL表实现数组功能


1.1 PL/SQL简介

   PL/SQL是ORACLE的过程化语言,包括一整套的数据类型、条件结构、循环结构和异常处理结构,PL/SQL可以执行SQL语句,SQL语句中也可以使用PL/SQL函数。

1.2 创建PL/SQL程序块

DECLARE

BEGIN

EXCEPTION
END;
1.3 PL/SQL数据类型

名称
 类型
 说明
 
NUMBER
 数字型
 能存放整数值和实数值,并且可以定义精度和取值范围
 
BINARY_INTEGER
 数字型
 可存储带符号整数,为整数计算优化性能
 
DEC
 数字型
 NUMBER的子类型,小数
 
DOUBLE PRECISION
 数字型
 NUMBER的子类型,高精度实数
 
INTEGER
 数字型
 NUMBER的子类型,整数
 
INT
 数字型
 NUMBER的子类型,整数
 
NUMERIC
 数字型
 NUMBER的子类型,与NUMBER等价
 
REAL
 数字型
 NUMBER的子类型,与NUMBER等价
 
SMALLINT
 数字型
 NUMBER的子类型,取值范围比INTEGER小
 
VARCHAR2
 字符型
 存放可变长字符串,有最大长度
 
CHAR
 字符型
 定长字符串
 
LONG
 字符型
 变长字符串,最大长度可达32,767
 
DATE
 日期型
 以数据库相同的格式存放日期值
 
BOOLEAN
 布尔型
 TRUE OR FALSE
 
ROWID
 ROWID
 存放数据库的行号
 

例子:
DECLARE
    ORDER_NO NUMBER(3);
    CUST_NAME VARCHAR2(20);
    ORDER_DATE DATE;
    EMP_NO INTEGER:=25;
    PI CONSTANT NUMBER:=3.1416;
BEGIN
  NULL;
END;
1.4 处理PL/SQL的异常

1.4.1 PL/SQL的异常

例如:
DECLARE
    X NUMBER;
BEGIN
    X:= 'yyyy';--Error Here
EXCEPTION   WHEN VALUE_ERROR THEN
    DBMS_OUTPUT.PUT_LINE('EXCEPTION HANDED');
END;

实现技术:
EXCEPTION WHEN first_exception THEN

WHEN second_exception THEN

WHEN OTHERS THEN
/*THERS异常处理器必须排在最后,它处理所有没有明确列出的异常。*/

END;

1.4.2 预定义异常

异常名称
 ORACLE错误
 说明
 
CURSOR_ALREADY_OPEN
 ORA-6511
 试图打开一个已打开的光标
 
DUP_VAL_ON_INDEX
 ORA-0001
 试图破坏一个唯一性限制
 
INVALID_CURSOR
 ORA-1001
 试图使用一个无效的光标
 
INVALID_NUMBER
 ORA-1722
 试图对非数字值进行数字操作
 
LOGIN_DENIED
 ORA-1017
 无效的用户名或者口令
 
NO_DATA_FOUND
 ORA-1403
 查询未找到数据
 
NOT_LOGGED_ON
 ORA-1012
 还未连接就试图数据库操作
 
PROGRAM_ERROR
 ORA-6501
 内部错误
 
ROWTYPE_MISMATCH
 ORA-6504
 主变量和光标的类型不兼容
 
STORAGE_ERROR
 ORA-6500
 内部错误
 
TIMEOUT_ON_RESOURCE
 ORA-0051
 发生超时
 
TOO_MANY_ROWS
 ORA-1422
 SELECT INTD命令返回的多行
 
TRANSACTION_BACKED_OUT
 ORA-006
 由于死锁提交被退回
 
VALUE_ERROR
 ORA-6502
 转换或者裁剪错误
 
ZERO_DIVIDE
 ORA-1476
 试图被零除
 

 

1.4.3 自定义异常处理

DECLARE
    BAD_ROWID EXCEPTION;
    X ROWID;
PRAGMA EXCEPTION_INIT(BAD_ROWID,-01445);
BEGIN
    SELECT ROWID INTO X FROM TAB
    WHERE ROWNUM=1;
EXCEPTION WHEN BAD_ROWID THEN
    DBMS_OUTPUT.PUT_LINE('CANNOT QUERY ROWID FROM THIS VIEW');
END;

    注意:-01445 因为PRAGMA EXCEPTION_INIT命令把这个变量(-01455)连接到
这个ORACLE错误,该语句的语法如下:
    PRAGMA EXCEPTION_INIT(exception_name, error_number);
其中error_number是负数,因为错误号被认为负数,当定义错误时记住使用负号

1.4.4 自定义异常

    异常不一定必须是oracle返回的系统错误,用户可以在自己的应用程序中创
建可触发及可处理的自定义异常
DECLARE
    SALARY_CODE VARCHAR2(1);
    INVALID_SALARY_CODE EXCEPTION;
BEGIN
    SALARY_CODE:='X';
    IF SALARY_CODE NOT IN('A', 'B', 'C') THEN
    RAISE INVALID_SALARY_CODE;
    END IF;
EXCEPTION WHEN INVALID_SALARY_CODE THEN
    DBMS_OUTPUT.PUT_LINE('INVALID SALARY CODE');
END;

1.5 在PL/SQL中单条记录的查询

    在PL/SQL内,有时在没有定义显式光标的情况下需要查询单条记录,并把记录的数据赋给变量。
DECLARE
    ln_dno NUMBER;
    lvs_dname VARCHAR2(40);
BEGIN
    SELECT DEPT_NO,DEPT_NAME
        INTO ln_dno,lvs_dname
    FROM dept
    WHERE DEPT_NO=1;
    DBMS_OUTPUT.PUT_LINE(TO_CHAR(ln_dno)||'.'||lvs_dname);
EXCEPTION WHEN NO_DATA_FOUND THEN
    DBMS_OUTPUT.PUT_LINE('NO DATA_FOUND');
    WHEN TOO_MANY_ROWS THEN
    DBMS_OUTPUT.PUT_LINE('TOO_MANY_ROWS');
END;

1.6 用光标查询多条记录

      光标(CURSOR)是指向一个称为上下文相关区的区域的指针,这个区域在服务器的处理过程全局区(PGA)内,当服务器上执行了一个查询后,查询返回的记录集存放在上下文相关区,通过光标上的操作可以把这些记录检索到客户端的应用程序。

1.6.1 使用光标的基本方法

DECLARE
    CURSOR C1 IS SELECT VIEW_NAME FROM ALL_VIEWS
        WHERE ROWNUM<=10
        ORDER BY VIEW_NAME;
    VNAME VARCHAR2(40);
BEGIN
    OPEN C1;
    FETCH C1 INTO VNAME;
    WHILE C1%FOUND LOOP
        DBMS_OUTPUT.PUT_LINE(TO_CHAR(C1%ROWCOUNT)||' '||VNAME);
        FETCH C1 INTO VNAME;
    END LOOP;
END;

属性
 含量
 
%FOUND
 布尔型属性,当最近一次该记录时成功返回,则值为TRUE
 
%NOTFOUND
 布尔型属性,它的值总与%FOUND属性的值相反
 
%ISOPEN
 布尔型属性,当光标是打开时返回TRUE
 
%ROWCOUNT
 数字型属性,返回已从光标中读取的记录数
 

 

1.6.2 使用光标FOR循环

DECLARE
    CURSOR C1 IS
    SELECT VIEW_NAME
        FROM ALL_VIEWS
        WHERE ROWNUM<=10
        ORDER BY VIEW_NAME;
BEGIN
    FOR I IN C1 LOOP
        DBMS_OUTPUT.PUT_LINE(I.VIEW_NAME);
    END LOOP;
END LOOP;
EXCEPTION WHEN OTHERS THEN
    NULL;
END;

1.6.3 带参数的光标

DECLARE
    CURSOR C1(VIEW_PATTERN VARCHAR2) IS
        SELECT VIEW_NAME
        FROM ALL_VIEWS
        WHERE VIEW_NAME LIKE VIEW_PATTERN||'%' AND
        ROWNUM<=10
        ORDER BY VIEW_NAME;
    VNAME VARCHAR2(40);
BEGIN
    FOR I IN C1('USER_AR') LOOP
        DBMS_OUTPUT.PUT_LINE(I.VIEW_NAME);
    END LOOP;
    DBMS_OUTPUT.PUT_LINE();
    FOR I IN C1('USER') LOOP
        DBMS_OUTPUT.PUT_LINE(I.VIEW_NAME);
    END LOOP;
EXCEPTION WHEN OTHERS THEN
    DBMS_OUTPUT.PUT_LINE('AAA');
END;

1.7 创建代表数据库记录和列的变量

变量名 基表名.列名%TYPE
DECLARE
    D_NO DEPT.DEPT_NO%TYPE;
    D_NAME DEPT.DEPT_NAME%TYPE;
BEGIN
    SELECT DEPT_NO,DEPT_NAME INTO D_NO,D_NAME
    FROM DEPT;
    DBMS_OUTPUT.PUT_LINE(TO_CHAR(D_NO));
EXCEPTION WHEN NO_DATA_FOUND THEN
    NULL;
END;

变量名 基表名%ROWTYPE
DECLARE
    D VEQU12%ROWTYPE;
BEGIN
    SELECT ASSET12ID,ASSET12NAME
        INTO D.ASSET12ID, D.ASSET12NAME
        FROM VEQU12;
    DBMS_OUTPUT.PUT_LINE(D.ASSET12ID);
EXCEPTION
WHEN NO_DATA_FOUND THEN
    NULL;
WHEN TOO_MANY_ROWS THEN
    DBMS_OUTPUT.PUT_LINE('TOO_MANY_ROWS');
END;
说明:
    当用户要创建一个变量来表示一个基表列或者要创建多个变量来代表一整条记录时,可以实际使用%TYPE属性和%ROWTYPE属性,使用%TYPE属性和%ROWTYPE属性可以保证当基表的结构或者其中某列的数据类型改变了时,用户的PL/SQL代码仍可正常工作。

1.9 怎样用PL/SQL表实现数组功能

    PL/SQL表与其他过程化语言(如C语言)的一维数组类似。实现PL/SQL表需要创建一个数据类型并另外进行变量说明。
    Type <类型名> Is
    Table Of <数据类型>
    Index by Binary_Integer;
以下为一个例子:
Declare
    Type Array_type is
        Table Of Number
        Index by Binary_Integer;
    My_Array Array_type;
Begin
    For I In 1..10 Loop
        My_Array(I) := I*2;
    End Loop;
    For I In 1..10 Loop
        Dbms_Output.Put_line(To_char(My_Array(I)));
    End Loop;
End;

分享到:
评论

相关推荐

    Oracle Database 10g PL/SQL入门教程

    Oracle Database 10g PL/SQL入门教程是针对初学者设计的一份教程,旨在帮助读者掌握Oracle数据库系统中PL/SQL编程语言的基础知识。PL/SQL是Oracle数据库特有的编程语言,它结合了SQL(结构化查询语言)的功能,用于...

    java中Oracle Database 10g PL/SQL入门教程

    【标题】"Java中Oracle Database 10g PL/SQL入门教程"的描述涉及了学习Java编程语言,并特别提到了Oracle Database 10g的PL/SQL编程。Oracle Database 10g是一款关系型数据库管理系统,广泛应用于企业级数据存储和...

    pl/sql入门教程

    plsql入门 游标变量 Oracle EXTRACT()函数 用Java调用存储过程 ORACLE用户常用数据字典的查询使用方法

    PL/SQL入门到精通书的源代码

    本资料“PL/SQL入门到精通书的源代码”是一份针对初学者到高级用户的实践教程,旨在帮助读者深入理解和掌握PL/SQL的各个方面。 在学习PL/SQL时,你需要了解以下几个关键知识点: 1. **基础语法**:PL/SQL由声明...

    Oracle存储过程和触发器(PL/SQL入门教程)

    Oracle存储过程和触发器(PL/SQL入门教程) Oracle存储过程和触发器(PL/SQL入门教程)

    ORACLE PL/SQL从入门到精通

    ORACLE PL/SQL是从入门到精通的专业知识,涵盖了数据库开发与管理的多个方面,包括触发器、过程、函数、软件包、异常处理、游标、循环、分支、变量使用、数据库安装等关键知识点。 触发器是数据库中用来保证数据...

    oracle pl/sql入门教程

    本入门教程旨在帮助初学者快速理解并掌握Oracle PL/SQL的基础知识,通过丰富的实例来解析其核心概念。 一、PL/SQL简介 PL/SQL是Oracle数据库提供的过程化语言,它允许开发者编写包含SQL语句的程序块,用于执行复杂...

    oracle pl/sql从入门到精通 配套源代码

    这本书"Oracle PL/SQL从入门到精通"的配套源代码,显然是为了帮助读者通过实践来深入理解和掌握Oracle数据库的编程技术。 首先,让我们探讨Oracle PL/SQL的基础知识。PL/SQL是Oracle数据库的内置编程语言,由块构成...

    Oracle 11g SQL和PL SQL从入门到精通 pdf格式电子书 下载(一)

    Oracle 11g SQL和PL SQL从入门到精通 pdf格式电子书 下载(一) http://download.csdn.net/source/3268267 Oracle 11g SQL和PL SQL从入门到精通 pdf格式电子书 下载(二) ...

    Oracle 11g SQL和PL SQL从入门到精通 pdf格式电子书 下载(二)

     本书是专门为oracle应用开发人员提供的sql和pl/sql编程指南。通过学习本书,读者不仅可以掌握oracle常用工具oracle universal installer、net comfiguration assistant、sql developer、sql*plus的作用及使用方法...

    Oracle PL/SQL程序设计(第5版)(上下册)

    ### Oracle PL/SQL程序设计(第5版)(上下册)知识点概述 #### 一、PL/SQL编程基础 - **PL/SQL简介**:PL/SQL(Procedural Language for SQL)是Oracle数据库的一种内嵌式过程化语言,用于增强SQL的功能。它允许在SQL...

    PL/SQL开发文档1

    标题中提到的“PL/SQL开发文档1”,说明本文档是关于PL/SQL开发的入门级指导材料,面向希望学习使用PL/SQL进行数据库程序单元开发的用户。文档很可能是Oracle公司内部或其授权的培训机构用于教学目的的官方材料。 ...

    pl/sql学习笔记

    PL/SQL(Procedural Language/Structured Query Language)是Oracle数据库中的过程式编程语言,它结合了SQL查询语句和传统的过程式编程元素,...对于初学者来说,找到合适的资源和教程,如本文档,是快速入门的关键。

    非常合适的PL/sql 入门

    【PL/SQL 入门详解】 PL/SQL(Procedural Language/Structured Query Language)是Oracle公司为标准SQL添加的编程扩展,它被深度集成到Oracle数据库系统中,成为数据库管理和开发的重要工具。PL/SQL提供了更丰富的...

    pl/sql基础教程

    以上只是PL/SQL基础教程的部分内容,完整的教程还将涵盖更多主题,如流程控制语句、游标、游标变量、集合、游标FOR循环、数据库连接、存储过程、函数、触发器、包、动态SQL以及性能优化等。掌握PL/SQL,对于开发和...

    Oracle PL/SQL编程及最佳实践

    Oracle PL/SQL 编程及最佳实践 Oracle PL/SQL 是一种高级编程语言,用于开发 Oracle 数据库中的存储过程、函数和触发器。PL/SQL language 提供了强大的编程能力,可以实现复杂的业务逻辑,并且与 Oracle 数据库紧密...

    oracle 经典资料及PL/SQL 使用指南 英文版

    这份指南的英文版将帮助读者从基础到高级全面掌握Oracle数据库和PL/SQL的使用,无论是入门学习还是提升技能,都能从中受益。通过阅读D33051.pdf、D33052.pdf、D32946.pdf、D32945.pdf这些文件,你可以逐步深入Oracle...

    Oracle10_PL/SQL培训教程

    这个“Oracle10_PL/SQL培训教程”是一个专为初学者设计的教程,旨在帮助用户快速掌握PL/SQL的基础知识和实际应用技巧。 PL/SQL,全称Procedural Language/Structured Query Language,是Oracle公司专门为数据库操作...

    Oracle11g SQL和PL/SQL从入门到精通.part1

    学习oracle sql pl/sql入门的很不错的一本书。

    pl/sql精通

    通过《PL/SQL从入门到精通》这本书,读者可以从基础开始逐步掌握这些概念和技术,提升在Oracle数据库开发和管理中的技能。书中的实例和练习将帮助读者深入理解并熟练运用PL/SQL,从而在实际工作中更有效地处理数据和...

Global site tag (gtag.js) - Google Analytics