Java 和 MySQL - 异常处理

异常处理允许您以受控方式处理异常情况,例如程序定义的错误。

当发生异常情况时,将引发异常。术语"引发"意味着当前程序执行停止,并且控制权将重定向到最近的 适用的 catch 子句。如果不存在适用的 catch 子句,则程序的执行结束。

JDBC 异常处理与 Java 异常处理非常相似,但对于 JDBC,您将处理的最常见异常是 java.sql.SQLException。

SQLException 方法

SQLException 可以同时发生在驱动程序和数据库中。发生此类异常时,将向 catch 子句传递 SQLException 类型的对象。

传递的 SQLException 对象具有以下方法可用于检索有关异常的其他信息 −

方法 描述
getErrorCode( ) 获取与异常相关的错误编号。
getMessage( ) 获取由驱动程序处理的错误的 JDBC 驱动程序错误消息,或获取数据库错误的 Oracle 错误编号和消息。
getSQLState( ) 获取 XOPEN SQLstate 字符串。对于 JDBC 驱动程序错误,此方法不会返回任何有用信息。对于数据库错误,将返回五位 XOPEN SQLstate 代码。此方法可以返回 null。
getNextException( ) 获取异常链中的下一个 Exception 对象。
printStackTrace( ) 打印当前异常或可抛出异常,并将其回溯打印到标准错误流。
printStackTrace(PrintStream s) 将此可抛出异常及其回溯打印到您指定的打印流。
printStackTrace(PrintWriter w) 将此可抛出异常及其回溯打印到您指定的打印编写器。

通过利用 Exception 中可用的信息对象,您可以捕获异常并适当地继续您的程序。以下是 try 块的一般形式 −

try {
    // 您的危险代码位于这些花括号之间!!!
}
catch(Exception ex) {
    // 您的异常处理代码位于这些
    // 花括号之间
}
finally {
    // 您的必须始终执行的代码位于这些
    // 花括号之间。例如关闭数据库连接。
}

示例

研究以下示例代码,了解 try....catch...finally 块的用法。

此代码是根据上一章中的环境和数据库设置编写的。

import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class TestApplication {
   static final String DB_URL = "jdbc:mysql://localhost/TUTORIALSPOINT";
   static final String USER = "guest";
   static final String PASS = "guest123";
   static final String QUERY = "{call getEmpName (?, ?)}";

   public static void main(String[] args) {
      // 打开连接
      try(Connection conn = DriverManager.getConnection(DB_URL, USER, PASS);
         CallableStatement stmt = conn.prepareCall(QUERY);
      ) {		      
         // 将值绑定到参数中。
         stmt.setInt(1, 1);  // This would set ID
         // 因为第二个参数是 OUT 所以注册它
         stmt.registerOutParameter(2, java.sql.Types.VARCHAR);
         //使用execute方法运行存储过程。
         System.out.println("Executing stored procedure..." );
         stmt.execute();
         //使用 getXXX 方法检索员工姓名
         String empName = stmt.getString(2);
         System.out.println("Emp Name with ID: 1 is " + empName);
      } catch (SQLException e) {
         e.printStackTrace();
      } 
   }
}

现在让我们编译上面的例子如下 −

C:\>javac TestApplication.java
C:\>

运行 TestApplication 时,如果没有问题,则会产生以下结果,否则将捕获相应的错误并显示错误消息 −

C:\>java TestApplication
Executing stored procedure...
Emp Name with ID: 1 is Zara
C:\>