JDBC - त्वरित गाइड

JDBC क्या है?

JDBC का मतलब है Jएवा Dएटीएbएएसई Connectivity, जो जावा प्रोग्रामिंग भाषा और डेटाबेस की एक विस्तृत श्रृंखला के बीच डेटाबेस-स्वतंत्र कनेक्टिविटी के लिए एक मानक जावा एपीआई है।

JDBC लाइब्रेरी में सामान्यतः डेटाबेस के उपयोग से जुड़े प्रत्येक कार्य के लिए API शामिल हैं:

  • किसी डेटाबेस से संबंध बनाना

  • SQL या MySQL स्टेटमेंट बनाना

  • डेटाबेस में उस SQL ​​या MySQL प्रश्नों का निष्पादन

  • परिणामी रिकॉर्ड देखना और संशोधित करना

पूर्व-अपेक्षा:

JDBC सीखने के लिए आपको निम्नलिखित दो विषयों पर अच्छी समझ होनी चाहिए:

  • कोर जावा प्रोग्रामिंग

  • SQL या MySQL डाटाबेस

JDBC - पर्यावरण सेटअप:

सुनिश्चित करें कि आपने निम्नलिखित सेटअप किया है:

  • कोर जावा स्थापना

  • SQL या MySQL डाटाबेस इंस्टॉलेशन

उपरोक्त के अलावा आपको एक डेटाबेस सेटअप करने की आवश्यकता है जिसे आप अपने प्रोजेक्ट के लिए उपयोग करेंगे। यह मानते हुए कि यह ईएमपी है और आपने एक ही डेटाबेस के भीतर टेबल एम्प्लॉइज पर बनाया है।

JDBC एप्लिकेशन बनाना:

JDBC एप्लिकेशन के निर्माण में छह चरण शामिल हैं, जिन्हें मैं इस ट्यूटोरियल में संक्षिप्त करने जा रहा हूँ:

पैकेज आयात करें:

इसके लिए आवश्यक है कि आप डेटाबेस प्रोग्रामिंग के लिए आवश्यक JDBC कक्षाओं वाले पैकेजों को शामिल करें। सबसे अधिक बार, आयात java.sql का उपयोग करना। * निम्नानुसार पर्याप्त होगा:

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

JDBC ड्राइवर पंजीकृत करें:

इसके लिए आवश्यक है कि आप एक ड्राइवर को इनिशियलाइज़ करें ताकि आप डेटाबेस के साथ एक संचार चैनल खोल सकें। इसे प्राप्त करने के लिए कोड स्निपेट निम्नलिखित है:

//STEP 2: Register JDBC driver
Class.forName("com.mysql.jdbc.Driver");

एक कनेक्शन खोलें:

कनेक्शन ऑब्जेक्ट बनाने के लिए DriverManager.getConnection () विधि का उपयोग करना आवश्यक है, जो डेटाबेस के साथ एक भौतिक कनेक्शन का प्रतिनिधित्व करता है:

//STEP 3: Open a connection
//  Database credentials
static final String USER = "username";
static final String PASS = "password";
System.out.println("Connecting to database...");
conn = DriverManager.getConnection(DB_URL,USER,PASS);

एक क्वेरी निष्पादित करें:

इसके लिए डेटाबेस के लिए एसक्यूएल स्टेटमेंट के निर्माण और प्रस्तुत करने के लिए टाइप स्टेटमेंट या रेडीस्टेडमेंट की एक वस्तु का उपयोग करना आवश्यक है:

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

यदि कोई SQL UPDATE, INSERT या DELETE विवरण आवश्यक है, तो निम्नलिखित कोड स्निपेट की आवश्यकता होगी:

//STEP 4: Execute a query
System.out.println("Creating statement...");
stmt = conn.createStatement();
String sql;
sql = "DELETE FROM Employees";
ResultSet rs = stmt.executeUpdate(sql);

परिणाम सेट से डेटा निकालें:

यदि आप डेटाबेस से डेटा प्राप्त कर रहे हैं तो यह चरण आवश्यक है। आप निम्न परिणाम के सेट से डेटा प्राप्त करने के लिए उपयुक्त ResultSet.getXXX () विधि का उपयोग कर सकते हैं:

//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();

पहला जेडीबीसी कार्यक्रम:

उपरोक्त चरणों के आधार पर, हमारे पास समेकित नमूना कोड हो सकता है, जिसे हम अपने JDBC कोड लिखते समय टेम्पलेट के रूप में उपयोग कर सकते हैं:

यह सैंपल कोड एन्वायरनमेंट चैप्टर में पर्यावरण और डेटाबेस सेटअप के आधार पर लिखा गया है।

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

public class FirstExample {
   // 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;
   Statement stmt = 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...");
      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(stmt!=null)
            stmt.close();
      }catch(SQLException se2){
      }// nothing we can do
      try{
         if(conn!=null)
            conn.close();
      }catch(SQLException se){
         se.printStackTrace();
      }//end finally try
   }//end try
   System.out.println("Goodbye!");
}//end main
}//end FirstExample

अब हम उदाहरण के ऊपर संकलन करते हैं:

C:\>javac FirstExample.java
C:\>

जब तुम दौड़ते हो FirstExample, यह निम्नलिखित परिणाम उत्पन्न करता है:

C:\>java FirstExample
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:\>

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

JDBC - डेटा प्रकार:

निम्न तालिका डिफ़ॉल्ट JDBC डेटा प्रकार को बताती है कि जब आप setXXX () रेडीएडस्टैटेमेंट या कॉलटेबल स्टेटमेंट ऑब्जेक्ट या ResultSet.updateXXX () विधि को कॉल करते हैं तो जावा डेटा प्रकार परिवर्तित होता है।

एसक्यूएल JDBC / जावा setXXX updateXXX
VARCHAR java.lang.String setString updateString
CHAR java.lang.String setString updateString
LONGVARCHAR java.lang.String setString updateString
बीआईटी बूलियन setBoolean updateBoolean
संख्यात्मक java.math.BigDecimal setBigDecimal updateBigDecimal
TINYINT बाइट setByte updateByte
SMALLINT कम setShort updateShort
पूर्णांक पूर्णांक setInt updateInt
BIGINT लंबा setLong updateLong
असली नाव setFloat updateFloat
फ्लोट नाव setFloat updateFloat
दोहरा दोहरा setDouble updateDouble
VARBINARY बाइट [] setBytes updateBytes
बायनरी बाइट [] setBytes updateBytes
दिनांक java.sql.Date तारीख सेट करें डेट अपडेट करें
समय java.sql.Time निर्धारित समय समय सुधारें
TIMESTAMP java.sql.Timestamp setTimestamp updateTimestamp
CLOB java.sql.Clob setClob updateClob
ब्लॉब java.sql.Blob setBlob updateBlob
सरणी java.sql.Array setARRAY updateARRAY
संदर्भ java.sql.Ref SetRef updateRef
struct java.sql.Struct SetStruct updateStruct

JDBC 3.0 ने BLOB, CLOB, ARRAY और REF डेटा प्रकारों के लिए समर्थन बढ़ाया है। ResultSet ऑब्जेक्ट में अब updateBLOB (), updateCLOB (), updateArray (), और updateRef () तरीके हैं जो आपको सर्वर पर संबंधित डेटा को सीधे हेरफेर करने में सक्षम करते हैं।

सेटएक्सएक्सएक्सएक्स () और अपडेटएक्सएक्सएक्सएक्सएक्स () विधियाँ आपको विशिष्ट जावा प्रकार को विशिष्ट जेडीबीसी डेटा प्रकारों में बदलने में सक्षम बनाती हैं। तरीकों, setObject () और updateObject (), आपको JDBC डेटा प्रकार के लगभग किसी भी जावा प्रकार को मैप करने में सक्षम करते हैं।

ResultSet ऑब्जेक्ट स्तंभ मान को प्राप्त करने के लिए प्रत्येक डेटा प्रकार के लिए इसी getXXX () विधि प्रदान करता है। प्रत्येक विधि का उपयोग स्तंभ नाम के साथ या इसकी क्रमिक स्थिति से किया जा सकता है।

एसक्यूएल JDBC / जावा setXXX getXXX
VARCHAR java.lang.String setString GetString
CHAR java.lang.String setString GetString
LONGVARCHAR java.lang.String setString GetString
बीआईटी बूलियन setBoolean getBoolean
संख्यात्मक java.math.BigDecimal setBigDecimal getBigDecimal
TINYINT बाइट setByte getByte
SMALLINT कम setShort getShort
पूर्णांक पूर्णांक setInt getInt
BIGINT लंबा setLong लंबा समय लें
असली नाव setFloat getFloat
फ्लोट नाव setFloat getFloat
दोहरा दोहरा setDouble getDouble
VARBINARY बाइट [] setBytes getBytes
बायनरी बाइट [] setBytes getBytes
दिनांक java.sql.Date तारीख सेट करें तारीख लें
समय java.sql.Time निर्धारित समय समय निकालो
TIMESTAMP java.sql.Timestamp setTimestamp getTimestamp
CLOB java.sql.Clob setClob getClob
ब्लॉब java.sql.Blob setBlob getBlob
सरणी java.sql.Array setARRAY getARRAY
संदर्भ java.sql.Ref SetRef getRef
struct java.sql.Struct SetStruct getStruct

JDBC - बैच प्रसंस्करण:

बैच प्रोसेसिंग आपको संबंधित SQL स्टेटमेंट को बैच में समूहित करने और उन्हें डेटाबेस में एक कॉल के साथ सबमिट करने की अनुमति देता है।

जब आप डेटाबेस में एक बार में कई SQL स्टेटमेंट भेजते हैं, तो आप संचार की मात्रा को कम कर देते हैं, जिससे प्रदर्शन में सुधार होता है।

  • JDBC ड्राइवरों को इस सुविधा का समर्थन करने की आवश्यकता नहीं है। यदि लक्ष्य डेटाबेस बैच अद्यतन प्रक्रिया का समर्थन करता है, तो आपको यह निर्धारित करने के लिए DatabaseMetaData.supportsBatchUpdates () विधि का उपयोग करना चाहिए । यदि आपका JDBC ड्राइवर इस सुविधा का समर्थन करता है तो यह विधि सही है।

  • addBatch()स्टेटमेंट, प्रिपेयडस्टैटेमेंट और कॉल करने योग्य स्टेटमेंट की विधि का उपयोग बैच में अलग-अलग स्टेटमेंट को जोड़ने के लिए किया जाता है। executeBatch() एक साथ समूहीकृत सभी कथनों के निष्पादन को शुरू करने के लिए उपयोग किया जाता है।

  • executeBatch() पूर्णांक का एक सरणी देता है, और सरणी का प्रत्येक तत्व संबंधित अद्यतन विवरण के लिए अद्यतन गणना का प्रतिनिधित्व करता है।

  • जैसे आप प्रसंस्करण के लिए एक बैच में बयान जोड़ सकते हैं, आप उन्हें हटा सकते हैं clearBatch()तरीका। यह विधि आपके द्वारा जोड़े गए सभी कथनों को AddBatch () विधि से हटा देती है। हालाँकि, आप चुनिंदा तरीके से नहीं निकाल सकते कि कौन सा स्टेटमेंट निकालना है।

JDBC - डेटा स्ट्रीमिंग:

एक तैयार किए गए ऑब्जेक्ट ऑब्जेक्ट में पैरामीटर डेटा की आपूर्ति करने के लिए इनपुट और आउटपुट स्ट्रीम का उपयोग करने की क्षमता है। यह आपको संपूर्ण फ़ाइलों को डेटाबेस कॉलम में रखने में सक्षम बनाता है जो बड़े मानों को पकड़ सकते हैं, जैसे कि CLOB और BLOB डेटा प्रकार।

निम्नलिखित तरीके हैं जो डेटा को स्ट्रीम करने के लिए उपयोग किए जा सकते हैं:

  • setAsciiStream(): इस पद्धति का उपयोग बड़े ASCII मूल्यों की आपूर्ति के लिए किया जाता है।

  • setCharacterStream(): इस पद्धति का उपयोग बड़े UNICODE मूल्यों की आपूर्ति के लिए किया जाता है।

  • setBinaryStream(): इस पद्धति का उपयोग बड़े द्विआधारी मूल्यों की आपूर्ति के लिए किया जाता है।

सेटएक्सएक्सएक्सस्ट्रीम () विधि में पैरामीटर प्लेसहोल्डर के अलावा एक अतिरिक्त पैरामीटर, फ़ाइल आकार की आवश्यकता होती है। यह पैरामीटर ड्राइवर को सूचित करता है कि स्ट्रीम का उपयोग करके डेटाबेस को कितना डेटा भेजा जाना चाहिए।

इन सभी अवधारणा पर विस्तार के लिए, आपको संपूर्ण ट्यूटोरियल से गुजरना होगा।