欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JDBC探索之SQLException解析

程序员文章站 2022-06-25 12:10:27
1. sqlexception 的概述 当使用 jdbc 与数据源(在本文中的数据源表示我们实际使用的数据库)进行交互的时候遇见错误的时候,将会抛出名为 sqlexc...

1. sqlexception 的概述

当使用 jdbc 与数据源(在本文中的数据源表示我们实际使用的数据库)进行交互的时候遇见错误的时候,将会抛出名为 sqlexception 的异常。一个 sqlexception 的异常里面包含以下信息,用于帮助我们更好的定位错误。

错误表示:

使用 getmessage 方法便可以获取。

sqlstate 代码

代码有五位的字母和数字组成 。多数的代码由 iso/ansi 和 open group(x/open) 标准化,但是仍然存在部分的代码由数据库提供商自行实现。

使用 getsqlstate 方法便可以获取。

错误代码

与 sqlstate 不同,错误代码是由数据库提供商自行定义的整数值,存在是由基础数据源返回的实际错误代码的可能。

使用 geterrorcode 方法便可以获取。

错误原因

表示引发异常的原因,通过不断调用 getcause 方法可以获取异常发生的底层原因。

异常链

如果出现多个错误,则通过此链引用异常。

使用 getnextexception 方法便可以获取。

2. sqlexception的示例

public static void printsqlexception(sqlexception e){
  for(throwable e :ex){
    if (e instanceof sqlexception){
      if(ignoresqlexception(((sqlexception)e).getsqlstate()) == false){
        e.printstacktrace(system.err);
        system.err.println("sqlstate:" + ((sqlexception)e).getsqlstate());
        system.err.println("error code:" + ((sqlexception)e).geterrorcode());
        system.err.println("message:" + e.getmessage());
        throwable t = ex.getcause();
        while(t != null){
          system.out.println("cause :" + t);
          t = t.getcause();
        }
      }
    }
  }
}
public static boolean ignoresqlexception(string sqlstate){
  if(sqlstate == null){
    system.out.println("the sql state is not defined");
  }
  // x0y32:jar file already exists in schema
  if(sqlstate.equalsignorecase("x0y32")){
    return true;
  }
  // 42y55:table already exists in schema
  if(sqlstate.equalsignorecase("42y55")){
    return true;
  }
  return true;
}

说明:上面的代码取自 [http:docs.oracle.com] ()。

3. sqlwarning

sqlwarning 是 sqlexception 的一个非常重要的子类,用于表示数据库访问时出现的警告。作为异常,sqlwarning 不会停止执行应用程序,而是提醒用户没有按计划发生任何事情。比如,警告有可能会通知你尝试撤销的某个权限没有成功,或者通知你在请求断开的时间可能发生错误。

sqlwarning 有可能被 connection 、statement (包括 preparedstatement 和 callablestatement)或 resultset 报告,这些类都存在 getwarnings 方法,通过调用该方法才能看到调用对象上报告的第一个警告。如果 getwarning 返回一个警告,我们可以调用其 getnextwarning 方法获取下一个警告。每执行一行语句,那么前面那行语句的警告将会清除,这意味着如果我们想要检索报告处理来的警告,那么必须在下一行语句执行之前检索。

datatruncation 是最常见的警告,其sqlstate代码均为01004,表示在读取和写入数据的时候存在问题。datatruncation 有很多方法可以帮助我们去理解哪个列或参数数据被截断,截断是在读取还是写入操作,应该传输多少字节以及实际传输的字节数。

4. 其他类型的sqlexception

batchupdateexception:在批处理更新操作期间发生错误时,将引发除了所提供的信息,提供的更新计数被处死之前出现了错误的所有语句。

sqlclientinfoexception:当无法在连接上设置一个或多个客户端信息属性时引发。除了所提供的信息,也提供了不设置的客户端信息属性的列表。

so on...

总结

以上就是本文关于jdbc探索之sqlexception解析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:jdbc常用接口总结使用jdbc实现数据访问对象层(dao)代码示例等,有什么问题可以随时留言,小编会及时回复大家的,欢迎大家留言交流讨论。