JDBC - अपवाद हैंडलिंग

अपवाद हैंडलिंग आपको नियंत्रित स्थिति में प्रोग्राम-परिभाषित त्रुटियों जैसी असाधारण स्थितियों को संभालने की अनुमति देता है।

जब एक अपवाद स्थिति होती है, तो एक अपवाद फेंक दिया जाता है। फेंका गया शब्द का मतलब है कि वर्तमान कार्यक्रम निष्पादन बंद हो जाता है, और नियंत्रण को निकटतम लागू कैच क्लॉज पर पुनर्निर्देशित किया जाता है। यदि कोई लागू कैच क्लॉज मौजूद नहीं है, तो प्रोग्राम का निष्पादन समाप्त हो जाता है।

JDBC एक्सेप्शन हैंडलिंग जावा एक्सेप्शन हैंडलिंग से काफी मिलती जुलती है, लेकिन JDBC के लिए, सबसे सामान्य अपवाद जो आप निपटेंगे java.sql.SQLException.

SQLException तरीके

ड्राइवर और डेटाबेस दोनों में एक SQLException हो सकती है। जब इस तरह का अपवाद होता है, तो SQLException प्रकार की एक वस्तु को पकड़ने के लिए पारित किया जाएगा।

पारित SQLException ऑब्जेक्ट में अपवाद के बारे में अतिरिक्त जानकारी प्राप्त करने के लिए निम्नलिखित तरीके उपलब्ध हैं -

तरीका विवरण
getErrorCode () अपवाद के साथ संबद्ध त्रुटि संख्या प्राप्त करता है।
getMessage () एक त्रुटि के लिए JDBC ड्राइवर के त्रुटि संदेश को प्राप्त करता है, चालक द्वारा नियंत्रित किया जाता है या डेटाबेस त्रुटि के लिए Oracle त्रुटि संख्या और संदेश प्राप्त करता है।
getSQLState () XOPEN SQLstate स्ट्रिंग हो जाता है। JDBC ड्राइवर त्रुटि के लिए, इस विधि से कोई उपयोगी जानकारी नहीं दी जाती है। डेटाबेस त्रुटि के लिए, पांच अंकों वाला XOPEN SQLstate कोड वापस आ जाता है। यह विधि अशक्त लौट सकती है।
getNextException () अपवाद श्रृंखला में अगली अपवाद वस्तु प्राप्त करता है।
PrintStackTrace () वर्तमान अपवाद या फेंकने योग्य प्रिंट करता है, और यह मानक त्रुटि स्ट्रीम के लिए बैकट्रेस है।
PrintStackTrace (PrintStream s) आपके द्वारा निर्दिष्ट प्रिंट स्ट्रीम के लिए इस थकाऊ और इसके बैकट्रेस को प्रिंट करता है।
PrintStackTrace (PrintWriter w) यह फेंकने योग्य प्रिंट करता है और यह आपके द्वारा निर्दिष्ट प्रिंट लेखक के लिए बैकट्रेस है।

अपवाद ऑब्जेक्ट से उपलब्ध जानकारी का उपयोग करके, आप एक अपवाद को पकड़ सकते हैं और अपने कार्यक्रम को उचित रूप से जारी रख सकते हैं। यहाँ एक कोशिश ब्लॉक का सामान्य रूप है -

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.
}

उदाहरण

के उपयोग को समझने के लिए निम्न उदाहरण कोड का अध्ययन करें try....catch...finally ब्लॉक।

//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

अब, उपरोक्त उदाहरण को संकलित करते हैं -

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

जब तुम दौड़ते हो JDBCExample, अगर कोई समस्या नहीं है, तो यह निम्नलिखित परिणाम उत्पन्न करता है, अन्यथा इसी त्रुटि को पकड़ा जाएगा और त्रुटि संदेश प्रदर्शित किया जाएगा -

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:\>

गलत डेटाबेस नाम या गलत उपयोगकर्ता नाम या पासवर्ड पास करके उपरोक्त उदाहरण का प्रयास करें और परिणाम की जांच करें।