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(): इस पद्धति का उपयोग बड़े द्विआधारी मूल्यों की आपूर्ति के लिए किया जाता है।
सेटएक्सएक्सएक्सस्ट्रीम () विधि में पैरामीटर प्लेसहोल्डर के अलावा एक अतिरिक्त पैरामीटर, फ़ाइल आकार की आवश्यकता होती है। यह पैरामीटर ड्राइवर को सूचित करता है कि स्ट्रीम का उपयोग करके डेटाबेस को कितना डेटा भेजा जाना चाहिए।
इन सभी अवधारणा पर विस्तार के लिए, आपको संपूर्ण ट्यूटोरियल से गुजरना होगा।