ORACLE ERROR CODE代表的意思

摘要:
标准SQLException提供了标准化的信息段和特定于供应商的信息段。Oracle数据库及其JDBC驱动程序通过ErrorCode提供的更丰富细节的一个明显例子是SQLState代码42000。相反,17003错误代码对应于OracleJDBC驱动程序错误代码ORA-17003。这两种类型的错误代码都是Oracle独有的。由于SQLState错误代码没有为源自Oracle JDBC驱动程序的错误提供,因此必须使用Oracle特定的错误代码来区分由JDBC驱动程序引起的错误。下面的表1列出了JDBC中访问Oracle数据库的一些最常见错误。

标准的 SQLException 提供了一个标准化的信息段 (SQLState) 和一个供应商特有的信息段 (ErrorCode)。正如大多数的数据库和它们的 JDBC 驱动程序实现一样,Oracle 数据库和 JDBC 驱动程序通过供应商特有的错误码所提供的关于问题的详细信息要比通过 SQLException 的与供应商无关的 SQLState 组件所提供的信息多得多。

Oracle 数据库及其 JDBC 驱动程序通过 Error Code 提供的更丰富得多的详细信息的一个明显的例子是 SQLState 代码 42000 (通常这指示语法错误或访问问题)。对于 Oracle JDBC 驱动程序的大量不同的 Oracle 错误码,SQLException 都将返回相同的 SQLState 值 (42000)。对应 SQLState 的 42000 值的一些 Oracle 错误码包括 900(“无效 SQL 语句”)、903(“无效表名”)、904(“无效标识符”)、911(“无效字符”)和 936(“缺少表达式”)。此外很明显任何来源于 Oracle JDBC 驱动程序的错误(与来源于 Oracle 数据库的错误相反)都没有任何对应的 SQLState。正如这些例子所显示那样,Oracle 特有的错误码所提供的关于错误情况的详细信息要比与供应商无关的 SQLState 所提供的信息更丰富得多。

有时候区分来源于 Oracle 数据库的错误和来源于 Oracle JDBC 驱动程序的错误非常重要。例如,903(“无效的表名”)错误码对应 Oracle 数据库错误码 ORA-00903。相反,17003(“无效的列索引”)错误码对应 Oracle JDBC 驱动程序错误码 ORA-17003。这两种类型的错误码(数据库和 JDBC 驱动程序)都是 Oracle 特有的(如 ORA- 前缀所指示的那样)。因为没有为来源于 Oracle JDBC 驱动程序的错误提供 SQLState 错误码,因此必须使用 Oracle 特有的错误码来区分由 JDBC 驱动程序导致的错误。

在下面的表 1 中列出了访问 Oracle 数据库的 JDBC 中的一些最常见的错误。“示例代码和/或注释”列中的示例显示了导致这种错误的 SQL 语句类型或提供了关于表中的该行上显示的特定错误的其他注释。

表 1

错误标记 Oracle 错误 SQLState 示例代码和/或注释

基于语句:SELECT ename FROM emp 变种的 SQL 相关错误

“唯一性约束” 1 2300 例如主键违规

“资源忙且指定 NOWAIT 获取资源”

54 61000 只有在指定了 NOWAIT 时才出现

“无效的 SQL 语句”

900 42000 ename FROM emp

“无效的表名”

903 42000 SELECT ename FROM

“无效的标识符”

904 42000 SELECT empname FROM emp

“无效的字符”

911 42000 SELECT ename FROM emp;

“缺少列”

917 42000 在 INSERT 语句中需要逗号来分隔列时遗漏逗号可能是一个原因。

“在期望的位置没有找到 FROM 关键字”

923 42000 SELECT ename emp

“缺少表达式”

936 42000 SELECT FROM emp

“表或视图不存在”

942 42000 SELECT ename FROM empp

“不能插入空值”

1400 23000 试图向包含 NOT NULL 约束的列中插入空值

“值大于该列的指定精度”

1438 22003 试图插入比列允许的精度更多的数字位数

“无效的数字”

1722 42000 试图对字符执行数值函数

“完整性约束失败”

2291 23000 试图插入包含与现有主键不匹配的外键的行

“值太大,”

12899 72000 试图插入超出列允许范围的的值(例如过多的字符)

“Io 异常”

17002 无 来源于 Oracle JDBC 驱动程序的错误没有对应的 SQLState (null)

“无效的列索引”

17003 无

“无效的列名”

17006 无

“数值溢出”

17026 无

免责声明:文章转载自《ORACLE ERROR CODE代表的意思》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇用html2canvas转html为图片遇到的那些问题一个用JavaScript生成思维导图(mindmap)的github repo下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

mybatis连接数据库

使用miproxy连接,存在过期连接的情况,经多次观察,属于研发配置错误,对于mybatis框架连接数据库需要同时启用 以下3个参数: testOnBorrow” value=”true” testOnReturn” value=”true” testWhileIdle” value=”true 一般连接池配置建议如下: <!-- 用...

MySQL之字段约束与权限管理

一、常见的字段约束在MySQL数据库中有许多常见的字段约束,所谓的字段约束就是在设置字段时需要给字段添加一些“枷锁”。 常见的字段约束有: INT(n)     数据类型及允许数据的个数 NOT NULL   非空 DEFAULT    默认值 PRIMARY KEY  主键约束,不能为空,不能重复,一般情况下一张表中至少要有一个主键 AUTO_INCR...

从零搭建 ES 搜索服务(二)基础搜索

一、前言 上篇介绍了 ES 的基本概念及环境搭建,本篇将结合实际需求介绍整个实现过程及核心代码。 二、安装 ES ik 分析器插件 2.1 ik 分析器简介 GitHub 地址:https://github.com/medcl/elasticsearch-analysis-ik 提供两种分词模式:「 ik_max_word 」及「 ik_smart 」...

liunx安装mysql(mariadb)

liunx安装mysql(mariadb) 1.配置mariadb的yum源,新建一个Mariadb.repo仓库文件#编辑创建mariadb.repo仓库文件  vi /etc/yum.repos.d/MariaDB.repo 2.修改mariadb.repo仓库文件,写入以下内容  vi /etc/yum.repos.d/MariaDB.repo   ...

GitLab 数据库

访问 GitLab 数据库 步骤 用的 Docker Gitlab,首先进入容器 docker exec -it gitlab /bin/bash `` 找到数据库配置文件 ```bash /var/opt/gitlab/gitlab-rails/etc/database.yml 内容如下,记录了数据库配置信息 production: adapter...

.NET Core前后端分离快速开发框架(Core.3.1+AntdVue)

.NET Core前后端分离快速开发框架(Core.3.1+AntdVue) 引言 简介 环境搭建 开发环境要求: 基础数据库构建: 数据库设计规范 运行 使用教程 系统配置 快速开发 管理员登录 系统用户管理 系统角色管理 权限管理 接口秘钥管理 系统日志 操作日志 事务使用 读写分离分库分表 常见疑问 如何进行联表查询 如何切换数据库...