JDBC - Penanganan Pengecualian

Penanganan pengecualian memungkinkan Anda untuk menangani kondisi luar biasa seperti kesalahan yang ditentukan program dengan cara yang terkontrol.

Ketika kondisi pengecualian terjadi, pengecualian dilemparkan. Istilah dilempar berarti bahwa eksekusi program saat ini berhenti, dan kontrol diarahkan ke klausa tangkapan terdekat yang berlaku. Jika tidak ada klausul catch yang berlaku, maka eksekusi program akan berakhir.

Penanganan JDBC Exception sangat mirip dengan penanganan Java Exception tetapi untuk JDBC, pengecualian paling umum yang akan Anda tangani adalah java.sql.SQLException.

Metode SQLException

SQLException dapat terjadi di driver dan database. Ketika pengecualian seperti itu terjadi, objek tipe SQLException akan diteruskan ke klausa catch.

Objek SQLException yang diteruskan memiliki metode berikut ini yang tersedia untuk mengambil informasi tambahan tentang pengecualian -

metode Deskripsi
getErrorCode () Mendapat nomor kesalahan yang terkait dengan pengecualian.
getMessage () Mendapat pesan kesalahan driver JDBC untuk kesalahan, ditangani oleh driver atau mendapatkan nomor dan pesan kesalahan Oracle untuk kesalahan database.
getSQLState () Mendapat string XOPEN SQLstate. Untuk kesalahan driver JDBC, tidak ada informasi berguna yang dikembalikan dari metode ini. Untuk kesalahan database, kode XOPEN SQLstate lima digit dikembalikan. Metode ini dapat mengembalikan null.
getNextException () Mengambil objek Exception berikutnya dalam rantai pengecualian.
printStackTrace () Mencetak pengecualian saat ini, atau dapat dibuang, dan pelacakan mundur ke aliran kesalahan standar.
printStackTrace (PrintStream s) Mencetak lemparan ini dan lacak baliknya ke aliran cetak yang Anda tentukan.
printStackTrace (PrintWriter w) Mencetak throwable ini dan lacak balik ke penulis cetak yang Anda tentukan.

Dengan memanfaatkan informasi yang tersedia dari objek Exception, Anda dapat menangkap pengecualian dan melanjutkan program Anda dengan tepat. Berikut adalah bentuk umum dari blok percobaan -

try {
   // Your risky code goes between these curly braces!!!
}
catch(Exception ex) {
   // Your exception handling code goes between these 
   // curly braces, similar to the exception clause 
   // in a PL/SQL block.
}
finally {
   // Your must-always-be-executed code goes between these 
   // curly braces. Like closing database connection.
}

Contoh

Pelajari kode contoh berikut untuk memahami penggunaan try....catch...finally blok.

//STEP 1. Import required packages
import java.sql.*;

public class JDBCExample {
   // JDBC driver name and database URL
   static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";  
   static final String DB_URL = "jdbc:mysql://localhost/EMP";

   //  Database credentials
   static final String USER = "username";
   static final String PASS = "password";
   
   public static void main(String[] args) {
   Connection conn = null;
   try{
      //STEP 2: Register JDBC driver
      Class.forName("com.mysql.jdbc.Driver");

      //STEP 3: Open a connection
      System.out.println("Connecting to database...");
      conn = DriverManager.getConnection(DB_URL,USER,PASS);

      //STEP 4: Execute a query
      System.out.println("Creating statement...");
      Statement stmt = conn.createStatement();
      String sql;
      sql = "SELECT id, first, last, age FROM Employees";
      ResultSet rs = stmt.executeQuery(sql);

      //STEP 5: Extract data from result set
      while(rs.next()){
         //Retrieve by column name
         int id  = rs.getInt("id");
         int age = rs.getInt("age");
         String first = rs.getString("first");
         String last = rs.getString("last");

         //Display values
         System.out.print("ID: " + id);
         System.out.print(", Age: " + age);
         System.out.print(", First: " + first);
         System.out.println(", Last: " + last);
      }
      //STEP 6: Clean-up environment
      rs.close();
      stmt.close();
      conn.close();
   }catch(SQLException se){
      //Handle errors for JDBC
      se.printStackTrace();
   }catch(Exception e){
      //Handle errors for Class.forName
      e.printStackTrace();
   }finally{
      //finally block used to close resources
      try{
         if(conn!=null)
            conn.close();
      }catch(SQLException se){
         se.printStackTrace();
      }//end finally try
   }//end try
   System.out.println("Goodbye!");
}//end main
}//end JDBCExample

Sekarang, mari kita kompilasi contoh di atas sebagai berikut -

C:\>javac JDBCExample.java
C:\>

Saat kamu lari JDBCExample, ini menghasilkan hasil berikut jika tidak ada masalah, jika tidak kesalahan yang sesuai akan tertangkap dan pesan kesalahan akan ditampilkan -

C:\>java JDBCExample
Connecting to database...
Creating statement...
ID: 100, Age: 18, First: Zara, Last: Ali
ID: 101, Age: 25, First: Mahnaz, Last: Fatma
ID: 102, Age: 30, First: Zaid, Last: Khan
ID: 103, Age: 28, First: Sumit, Last: Mittal
C:\>

Coba contoh di atas dengan memasukkan nama database yang salah atau nama pengguna atau kata sandi yang salah dan periksa hasilnya.