网站首页 > 技术文章 正文
概述
oracle 有三种方式可以抛出异常,分别是:
① 通过PL/SQL运行引擎
② 使用RAISE语句
③ 调用RAISE_APPLICATION_ERROR存储过程
当数据库或PL/SQL在运行时发生了错误,此时的异常可以通过PL/SQL运行时的引擎自动抛出异常,这个无需过度关注。第二种是通过RAISE语句抛出异常,语法如下所示:
RAISE exception_name;
显式抛出异常是程序员处理声明的异常的习惯用法,但RAISE不限于声明了的异常,它可以抛出任何异常。比如下面一个订单输入的例子,若当订单大于库存数量,则抛出异常,并且捕获该异常、处理该异常。关键的代码部分如下所示:
DECLARE INVENTORY_TOO_LOW EXCEPTION; ---其他声明语句 BEGIN IF ORDER.QTY > INVENTORY.QTY THEN RAISE INVENTORY_TOO_LOW; END IF; EXCEPTION WHEN INVENTORY_TOO_LOW THEN ORDER.STATUS := 'INVENTORY_LOW'; END;
第三种抛出异常的办法是通过RAISE_APPLICATION_ERROR语句。RAISE_APPLICATION_ERROR是一个内建函数,它用于抛出一个异常并给异常赋予一个错误号以及错误信息,它将应用程序专有的错误从服务器端转达到客户端应用程序(其它机器上的SQL*Plus或者其它前台开发语言)。该函数可以在PL/SQL程序块的执行部分和异常部分被调用。
RAISE_APPLICATION_ERROR的声明:
RAISE_APPLICATION_ERROR(ERROR_NUMBER IN NUMBER,MESSAGE IN VARCHAR2[,TRUE,FALSE]))
错误号的范围是-20000到-20999,这样就不会与Oracle的任何错误代码发生冲突。错误信息是文本字符串,最多为2048字节。TRUE和FALSE表示是添加(TRUE)进错误堆栈(ERROR STACK)还是覆盖(OVERWRITE)错误堆栈(FALSE)。缺省情况下是FALSE。
RAISE_APPLICATION_ERROR使用示例如下所示:
IF PRODUCT_NOT_FOUND THEN RAISE_APPLICATION_ERROR(-20123,'INVALD PRODUCT CODE',TRUE); END IF;
当函数用于触发器并且触发事件在以下情况的时候并不能抛出错误:
① 触发事件为“AFTER STARTUP ON DATABASE”或“BEFORE SHUTDOWN ON DATABASE”;
② 触发事件为“AFTER LOGON ON DATABASE”且用户拥有“ADMINISTER DATABASE TRIGGER”权限;
③ 触发事件为“AFTER LOGON ON SCHEMA”且用户拥有“ALTER ANY TRIGGER”权限。
后面会分享更多关于运维DBA方面的内容,感兴趣的朋友可以关注下~
猜你喜欢
- 2024-10-20 图解oracle数据库SQL的各个连接方式:inner join、left join等
- 2024-10-20 一文看懂oracle三大类型与隐式数据类型转换
- 2024-10-20 oracle学习随笔一(索引) oracle索引怎么使用
- 2024-10-20 Oracle解析复杂json的方法 oracle处理json格式数据
- 2024-10-20 oracle 各种报告收集方法 oracle收集表信息
- 2024-10-20 详解oracle RMAN 用法:连接方式+基本指令
- 2024-10-20 Python 操作Oracle数据库常用的方法和工具
- 2024-10-20 数据库程序在线访问方式和 ORM 方式的优缺点
- 2024-10-20 关于数据库oracle认证方式 oracle数据库管理员认证
- 2024-10-20 详解Oracle并行模式--概念、机制、并行设置、并行度
你 发表评论:
欢迎- 07-10Oracle 与 Google Cloud 携手大幅扩展多云服务
- 07-10分享收藏的 oracle 11.2.0.4各平台的下载地址
- 07-10Oracle 和 Microsoft 推出 Oracle Exadata 数据库服务
- 07-10Oracle Database@Azure 推进到南美等新区域并增加了新服务
- 07-10Oracle宣布推出 Oracle Database@AWS 的有限预览版
- 07-10Oracle与Nextcloud合作,推出主权云上的安全协作平台
- 07-10NodeRED魔改版连接MsSql、PostgreSQL、MySQL、OracleDB存储无忧
- 07-10对于企业数据云备份,“多备份”承诺的是成本更低,管理更高效#36氪开放日深圳站#
- 605℃几个Oracle空值处理函数 oracle处理null值的函数
- 597℃Oracle分析函数之Lag和Lead()使用
- 585℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 581℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 576℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 570℃【数据统计分析】详解Oracle分组函数之CUBE
- 557℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 550℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- Oracle 与 Google Cloud 携手大幅扩展多云服务
- 分享收藏的 oracle 11.2.0.4各平台的下载地址
- Oracle 和 Microsoft 推出 Oracle Exadata 数据库服务
- Oracle Database@Azure 推进到南美等新区域并增加了新服务
- Oracle宣布推出 Oracle Database@AWS 的有限预览版
- Oracle与Nextcloud合作,推出主权云上的安全协作平台
- NodeRED魔改版连接MsSql、PostgreSQL、MySQL、OracleDB存储无忧
- 对于企业数据云备份,“多备份”承诺的是成本更低,管理更高效#36氪开放日深圳站#
- 解读丨《归档文件整理规则》— 电子文件元数据存储
- Data Guard跳归档恢复的实践(dataguard failover)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (57)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)