IBATIS处理typeHandler类容易范的SQLException总结

本文针对四种常见的java.sql.SQLException异常进行了解析,包括无效的列类型、内部错误:Inconsistent catalog view、索引中丢失 IN或OUT参数及ORA-00907:missing right parenthesis等问题,并提供了可能的原因分析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. java.sql.SQLException: 无效的列类型

原因:

 A. ibatis的IN,OUT参数、或者typeHandler类中传入的参数值数据类型与Oracle自定义对象中的属性值的数据类型不相符;

 B. call SQL语句串中的?号数目与实际PKG子过程中的变量数目不一致;

2. java.sql.SQLException: 内部错误: Inconsistent catalog view

原因:

typeHandler类中"createDescriptor"中调用的Oracle自定义对象写错、或者调用的Oracle自定义对象没有对该SQL的执行用户授权;

3. java.sql.SQLException: 索引中丢失  IN 或 OUT 参数:: 1

原因:

ibatis的IN,OUT参数、或者typeHandler类中get的参数名写错;

4. java.sql.SQLException: ORA-00907: missing right parenthesis

原因:

SQL语句中有结束符号导致匹配不到右括号;

转载于:https://www.cnblogs.com/for-if-else/p/3203032.html

其他还有很多异常,我就不一一列举了,我要说明的是,一个合格的程序员,需要对程序中常见的问题有相当的了解和相应的解决办法,否则仅仅停留在写程序而不会改程序的话,会极大影响到自己的开发的。关于异常的全部说明,在api里都可以查阅。 算术异常:ArithmeticExecption 空指针异常:NullPointerException 型强制转换异常:ClassCastException 数组负下标异常:NegativeArrayException 数组下标越界异常:ArrayIndexOutOfBoundsException 违背安全原则异常:SecturityException 文件已结束异常:EOFException 文件未找到异常:FileNotFoundException 字符串转换为数字异常:NumberFormatException 操作数据库异常:SQLException 输入输出异常:IOException 方法未找到异常:NoSuchMethodException java.lang.AbstractMethodError 抽象方法错误。当应用试图调用抽象方法时抛出。 java.lang.AssertionError 断言错。用来指示一个断言失败的情况。 java.lang.ClassCircularityError 循环依赖错误。在初始化一个时,若检测到之间循环依赖则抛出该异常。 java.lang.ClassFormatError 格式错误。当Java虚拟机试图从一个文件中读取Java,而检测到该文件的内容不符合的有效格式时抛出。 java.lang.Error 错误。是所有错误的基,用于标识严重的程序运行问题。这些问题通常描述一些不应被应用程序捕获的反常情况。 java.lang.ExceptionInInitializerError 初始化程序错误。当执行一个的静态初始化程序的过程中,发生了异常时抛出。静态初始化程序是指直接包含于中的static语句段。 java.lang.IllegalAccessError 违法访问错误。当一个应用试图访问、修改某个的域(Field)或者调用其方法,但是又违反域或方法的可见性声明,则抛出该异常。 java.lang.IncompatibleClassChangeError 不兼容的变化错误。当正在执行的方法所依赖的定义发生了不兼容的改变时,抛出该异常。一般在修改了应用中的某些的声明定义而没有对整个应用重新编译而直接运行的情况下,容易引发该错误。 java.lang.InstantiationError 实例化错误。当一个应用试图通过Java的new操作符构造一个抽象或者接口时抛出该异常. java.lang.InternalError 内部错误。用于指示Java虚拟机发生了内部错误。 java.lang.LinkageError 链接错误。该错误及其所有子指示某个依赖于另外一些,在该编译之后,被依赖的改变了其定义而没有重新编译所有的,进而引发错误的情况。 java.lang.NoClassDefFoundError 未找到定义错误。当Java虚拟机或者装载器试图实例化某个,而找不到该的定义时抛出该错误。 java.lang.NoSuchFieldError 域不存在错误。当应用试图访问或者修改某的某个域,而该的定义中没有该域的定义时抛出该错误。 java.lang.NoSuchMethodError 方法不存在错误。当应用试图调用某的某个方法,而该的定义中没有该方法的定义时抛出该错误。 java.lang.OutOfMemoryError 内存不足错误。当可用内存不足以让Java虚拟机分配给一个对象时抛出该错误。 java.lang.StackOverflowError 堆栈溢出错误。当一个应用递归调用的层次太深而导致堆栈溢出时抛出该错误。 java.lang.ThreadDeath 线程结束。当调用Thread的stop方法时抛出该错误,用于指示线程结束。 java.lang.UnknownError 未知错误。用于指示Java虚拟机发生了未知严重错误的情况。 java.lang.UnsatisfiedLinkError 未满足的链接错误。当Java虚拟机未找到某个的声明为native方法的本机语言定义时抛出。 java.lang.UnsupportedClassVersionError 不支持的版本错误。当Java虚拟机试图从读取某个文件,但是发现该文件的主、次版本号不被当前Java
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值