一:异常

程序执行过程中出现错误情况被称为异常,主要有两种类型的异常:

  • 系统定义的异常

  • 用户定义的异常

二:系统定义的异常

Exception Oracle Error SQLCODE 描述
ACCESS_INTO_NULL 06530 -6530 为空对象赋值时引发
CASE_NOT_FOUND 06592 -6592 没有相应的选择语句时引发异常
COLLECTION_IS_NULL 06531 -6531 数组、集合未初始化却被使用时引发异常
DUP_VAL_ON_INDEX 00001 -1 当重复值试图被存储在具有唯一索引的列时被引发
INVALID_CURSOR 01001 -1001 游标操作异常
INVALID_NUMBER 01722 -1722 当一个字符串转换成一个数失败时引发
LOGIN_DENIED 01017 -1017 当使用无效的用户名或密码登录数据库时引发
NO_DATA_FOUND 01403 +100 当一个SELECT INTO语句无任何行返回时引发
NOT_LOGGED_ON 01012 -1012 在未连接到数据库却发出数据库调用时被引发
PROGRAM_ERROR 06501 -6501 当PL/SQL有一个程序内部错误时引发
ROWTYPE_MISMATCH 06504 -6504 当游标取值有不兼容的数据类型的变量被引发
SELF_IS_NULL 30625 -30625 当对象的成员方法被调用但对象类型的实例没有被初始化时引发异常
STORAGE_ERROR 06500 -6500 当PL/SQL内存不足或内存已损坏时引发异常
TOO_MANY_ROWS 01422 -1422 当SELECT INTO语句返回多行时引发异常
VALUE_ERROR 06502 -6502 算术、转换、截短或大小约束错误时引发
ZERO_DIVIDE 01476 1476 0作除数时引发异常

三:用户自定义异常(其实就是声明一个异常变量)

  1. DECLARE
  2. my-exception EXCEPTION;

四:手动抛出异常

  1. DECLARE
  2. exception_name EXCEPTION;
  3. BEGIN
  4. IF condition THEN
  5. RAISE exception_name;
  6. END IF;
  7. EXCEPTION
  8. WHEN exception_name THEN
  9. statement;
  10. END;

五:异常处理

  1. DECLARE
  2. <declarations section>
  3. BEGIN
  4. <executable command(s)>
  5. EXCEPTION //异常处理部分
  6. WHEN exception1 THEN
  7. exception1-handling-statements
  8. WHEN exception2 THEN
  9. exception2-handling-statements
  10. WHEN exception3 THEN
  11. exception3-handling-statements
  12. ........
  13. WHEN others THEN
  14. exception3-handling-statements
  15. END;

PL/SQL学习笔记之异常的更多相关文章

  1. ORALCE PL/SQL学习笔记

    ORALCE  PL/SQL学习笔记 详情见自己电脑的备份数据资料

  2. Oracle之PL/SQL学习笔记

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

  3. [Oracle] PL/SQL学习笔记

    -- 1. 使用一个变量 declare -- Local variables here v_name ); begin -- Test statements here select t.user_n ...

  4. PL\SQL学习笔记

    注释 单行--多行 一.declare一般用于做变量的申明.begin 程序体开始执行  end; 程序体结束exception .. dbms_output.put_line('绝对值'||v_ab ...

  5. PL/SQL学习笔记_01_基础

    PL/SQL语句可以在Oracle客户端的 SQL窗口或者 command  窗口中运行 在SQL窗口中运行步骤同 SQL语句 在command  窗口中运行的步骤如下: 1)File—new com ...

  6. PL/SQL学习笔记程序单元

    一:程序单元组成 一个PL/SQL程序单元主要包括三部分: 声明与定义部分:声明变量.常量.类型等:定义过程.函数等: 执行部分:执行PL/SQL语句:调用过程.参数:处理游标等: 异常处理部分:处理 ...

  7. PL/SQL学习笔记之包

    一:包 包是由一组相关的函数,过程,变量,游标等PL/SQL程序设计元素的组合而成的一个PL/SQL程序单元,相当于Java中的类. 包的主要作用是封装:把相同或相似的东西归类,方便维护和管理,提高开 ...

  8. PL/SQL学习笔记之集合

    一:PL/SQL集合 集合是一个有序且存有相同的类型数据的数据结构. PL/SQL提供了三种集合类型: 索引表(关联数组) 嵌套表 数组 二:索引表:一个索引表(也叫关联数组)是一组键 - 值对.每个 ...

  9. PL/SQL学习笔记之基本块格式与语法

    一:PL/SQL程序块 PL/SQL是一种块结构的语言,一个PL/SQL程序就是一个 代码逻辑块. PL/SQL程序由三部分构成: 1 声明 部分 使用关键字DECLARE开头,它是一个可选的部分,用 ...

随机推荐

  1. java根据word模板导出word文件

    1.word模板文件处理,如下图所示在word 文档中填值的地方写入占位变量 2.将word文档另存为xml文件.编辑如下图,找到填写的占位,修改为${bcrxm}格式 3.将文件后缀名改为.ftl文 ...

  2. 步步为营-53-JavaScript

    说明 :JS比较常用 1.1 常见的两种使用方式: 1.1.1 直接使用 <script>alert('Hello,World')</script>      1.1.2 引用 ...

  3. stl 常用代码

    CString类型的replace ; while((pos = it->m_strFile.find(_T("%UC_INSTALL_ROOT%\\"), pos)) != ...

  4. 【C++ Primer | 15】C++虚函数表剖析①

    概述 为了实现C++的多态,C++使用了一种动态绑定的技术.这个技术的核心是虚函数表(下文简称虚表).本文介绍虚函数表是如何实现动态绑定的. C++多态实现的原理: •  当类中声明虚函数时,编译器会 ...

  5. c++ primer 笔记 (一)

    昨天开始看的<C++ Primer>,确实不错.希望这周抓紧看完,每天做下笔记,以便以后复习. main函数返回一个值给操作系统   操作系统通过main函数返回的值来确定程序是否成功执行 ...

  6. guava常用

    教程: http://www.yiibai.com/guava/ http://ifeve.com/google-guava/ optional 注意java8同样提供optional,区分 意义: ...

  7. POJ1006 Biorhythms【中国剩余定理】

    <题目链接> 题目大意: 人体的体力每23天会达到峰值,情感每28天会达到峰值,智力每33天会达到峰值,一个人在a天体力达到峰值,b天情感达到峰值,c天智力达到峰值,求这个人下一次体力情感 ...

  8. hdu 5748 Bellovin【最长上升子序列】

    题目链接:https://vjudge.net/contest/148584#problem/A 题目大意: 解题思路:题目要求为:输出与已知序列的每一个元素的f(i)(f(i)的定义如题)相同的字典 ...

  9. NumPy学习(让数据处理变简单)

    NumPy学习(一) NumPy数组创建 NumPy数组属性 NumPy数学算术与算数运算 NumPy数组创建 NumPy 中定义的最重要的对象是称为 ndarray 的 N 维数组类型. 它描述相同 ...

  10. 006.Docker网络管理

    一 docker网络模式 Docker使用Linux的Namespaces技术来进行资源隔离,如PID Namespace隔离进程,Mount Namespace隔离文件系统,Network Name ...