JDBC - डेटाबेस कनेक्शन
उपयुक्त ड्राइवर स्थापित करने के बाद, यह JDBC का उपयोग करके डेटाबेस कनेक्शन स्थापित करने का समय है।
JDBC कनेक्शन स्थापित करने के लिए शामिल प्रोग्रामिंग काफी सरल है। ये सरल चार चरण हैं -
Import JDBC Packages: जोड़ना import अपने जावा कोड में अपने जावा कोड में आवश्यक कक्षाएं आयात करने के लिए कार्यक्रम।
Register JDBC Driver: यह कदम JVM को वांछित ड्राइवर कार्यान्वयन को मेमोरी में लोड करने का कारण बनता है ताकि यह आपके JDBC अनुरोधों को पूरा कर सके।
Database URL Formulation: यह ठीक से स्वरूपित पता बनाने के लिए है जो उस डेटाबेस को इंगित करता है जिससे आप कनेक्ट करना चाहते हैं।
Create Connection Object:अंत में, वास्तविक डेटाबेस कनेक्शन को स्थापित करने के लिए DriverManager ऑब्जेक्ट के getConnection () विधि के लिए एक कॉल कोड करें ।
JDBC पैकेज आयात करें
Import विवरण जावा संकलक को बताते हैं कि आप अपने कोड में जिन कक्षाओं को संदर्भित करते हैं, उन्हें कहां से ढूंढना है और आपके स्रोत कोड की शुरुआत में रखा गया है।
मानक JDBC पैकेज का उपयोग करने के लिए, जो आपको SQL टेबल में डेटा को चुनने, डालने, अपडेट करने और हटाने की अनुमति देता है, अपने सोर्स कोड में निम्न आयात जोड़ें -
import java.sql.* ; // for standard JDBC programs
import java.math.* ; // for BigDecimal and BigInteger support
रजिस्टर JDBC ड्राइवर
उपयोग करने से पहले आपको अपने प्रोग्राम में ड्राइवर को पंजीकृत करना होगा। ड्राइवर को पंजीकृत करना वह प्रक्रिया है जिसके द्वारा ओरेकल ड्राइवर की क्लास फाइल को मेमोरी में लोड किया जाता है, इसलिए इसे JDBC इंटरफेस के कार्यान्वयन के रूप में उपयोग किया जा सकता है।
आपको यह पंजीकरण केवल एक बार अपने कार्यक्रम में करने की आवश्यकता है। आप दो तरीकों में से एक में एक चालक को पंजीकृत कर सकते हैं।
दृष्टिकोण I - Class.forName ()
ड्राइवर को पंजीकृत करने के लिए सबसे आम तरीका जावा का उपयोग करना है Class.forName()विधि, ड्राइवर की क्लास फाइल को गतिशील रूप से मेमोरी में लोड करने के लिए, जो इसे स्वचालित रूप से पंजीकृत करता है। यह विधि बेहतर है क्योंकि यह आपको ड्राइवर पंजीकरण को विन्यास और पोर्टेबल बनाने की अनुमति देता है।
निम्न उदाहरण Oracle ड्राइवर को पंजीकृत करने के लिए Class.forName () का उपयोग करता है -
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
}
catch(ClassNotFoundException ex) {
System.out.println("Error: unable to load driver class!");
System.exit(1);
}
आप उपयोग कर सकते हैं getInstance() गैर-संयोजक जेवीएम के आसपास काम करने की विधि, लेकिन फिर आपको दो अतिरिक्त अपवादों के लिए कोड करना होगा -
try {
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
}
catch(ClassNotFoundException ex) {
System.out.println("Error: unable to load driver class!");
System.exit(1);
catch(IllegalAccessException ex) {
System.out.println("Error: access problem while loading!");
System.exit(2);
catch(InstantiationException ex) {
System.out.println("Error: unable to instantiate driver!");
System.exit(3);
}
दृष्टिकोण II - DriverManager.registerDriver ()
दूसरा दृष्टिकोण जो आप ड्राइवर को पंजीकृत करने के लिए उपयोग कर सकते हैं, वह है स्थैतिक का उपयोग करना DriverManager.registerDriver() तरीका।
यदि आप Microsoft द्वारा प्रदान किए गए गैर-JDK अनुरूप JVM का उपयोग कर रहे हैं, तो आपको registerDriver () पद्धति का उपयोग करना चाहिए ।
निम्नलिखित उदाहरण Oracle चालक को पंजीकृत करने के लिए registerDriver () का उपयोग करता है -
try {
Driver myDriver = new oracle.jdbc.driver.OracleDriver();
DriverManager.registerDriver( myDriver );
}
catch(ClassNotFoundException ex) {
System.out.println("Error: unable to load driver class!");
System.exit(1);
}
डेटाबेस URL निरूपण
आपके द्वारा ड्राइवर लोड करने के बाद, आप कनेक्शन का उपयोग करके कनेक्शन स्थापित कर सकते हैं DriverManager.getConnection()तरीका। आसान संदर्भ के लिए, मैं तीन अधिभार DriverManager.getConnection () विधियों को सूचीबद्ध करता हूं -
getConnection (स्ट्रिंग url)
getConnection (स्ट्रिंग url, गुण प्रोप)
getConnection (स्ट्रिंग url, स्ट्रिंग उपयोगकर्ता, स्ट्रिंग पासवर्ड)
यहां प्रत्येक फॉर्म के लिए डेटाबेस की आवश्यकता होती है URL। एक डेटाबेस URL एक पता है जो आपके डेटाबेस को इंगित करता है।
डेटाबेस URL तैयार करना वह जगह है जहाँ कनेक्शन स्थापित करने से जुड़ी अधिकांश समस्याएं होती हैं।
निम्न तालिका JDBC ड्राइवर के लोकप्रिय नामों और डेटाबेस URL को सूचीबद्ध करती है।
आरडीबीएमएस | JDBC ड्राइवर का नाम | URL प्रारूप |
---|---|---|
माई एसक्यूएल | com.mysql.jdbc.Driver | jdbc:mysql://होस्टनाम / डेटाबेसनाम |
आकाशवाणी | oracle.jdbc.driver.OracleDriver | jdbc:oracle:thin:@होस्टनाम: पोर्ट नंबर: डेटाबेसनाम |
डीबी 2 | COM.ibm.db2.jdbc.net.DB2Driver | jdbc:db2:होस्टनाम: पोर्ट नंबर / डेटाबेसनाम |
साइबेस | com.sybase.jdbc.SybDriver | jdbc:sybase:Tds:होस्टनाम: पोर्ट नंबर / डेटाबेसनाम |
URL प्रारूप में सभी हाइलाइट किया गया भाग स्थिर है और आपको अपने डेटाबेस सेटअप के अनुसार केवल शेष भाग को बदलने की आवश्यकता है।
कनेक्शन ऑब्जेक्ट बनाएँ
हमने तीन रूपों को सूचीबद्ध किया है DriverManager.getConnection() कनेक्शन ऑब्जेक्ट बनाने की विधि।
उपयोगकर्ता नाम और पासवर्ड के साथ डेटाबेस URL का उपयोग करना
GetConnection () का सबसे अधिक उपयोग किया जाने वाला फ़ॉर्म आपको एक डेटाबेस URL, एक उपयोगकर्ता नाम और एक पासवर्ड पारित करने की आवश्यकता है :
मान लें कि आप Oracle का उपयोग कर रहे हैं thin ड्राइवर, आप एक होस्ट निर्दिष्ट करेंगे: URL के डेटाबेस भाग के लिए portName मान।
यदि आपके पास amrood के होस्ट नाम के साथ TCP / IP एड्रेस 192.0.0.1 पर एक होस्ट है, और आपका Oracle श्रोता पोर्ट 1521 पर सुनने के लिए कॉन्फ़िगर किया गया है, और आपके डेटाबेस का नाम ईएमपी है, तो पूरा डेटाबेस URL होगा -
jdbc:oracle:thin:@amrood:1521:EMP
अब आपको getConnection () मेथड को उपयुक्त यूजरनेम और पासवर्ड के साथ कॉल करना होगा Connection वस्तु इस प्रकार है -
String URL = "jdbc:oracle:thin:@amrood:1521:EMP";
String USER = "username";
String PASS = "password"
Connection conn = DriverManager.getConnection(URL, USER, PASS);
केवल एक डेटाबेस URL का उपयोग करना
DriverManager.getConnection () विधि का दूसरा रूप केवल एक डेटाबेस URL की आवश्यकता है -
DriverManager.getConnection(String url);
हालाँकि, इस मामले में, डेटाबेस URL में उपयोगकर्ता नाम और पासवर्ड शामिल हैं और निम्नलिखित सामान्य रूप हैं -
jdbc:oracle:driver:username/password@database
तो, उपरोक्त कनेक्शन निम्नानुसार बनाया जा सकता है -
String URL = "jdbc:oracle:thin:username/password@amrood:1521:EMP";
Connection conn = DriverManager.getConnection(URL);
डेटाबेस URL और गुण ऑब्जेक्ट का उपयोग करना
DriverManager.getConnection () विधि के तीसरे रूप के लिए डेटाबेस URL और गुण ऑब्जेक्ट की आवश्यकता होती है -
DriverManager.getConnection(String url, Properties info);
प्रॉपर्टीज ऑब्जेक्ट कीवर्ड-वैल्यू पेयर का एक सेट रखता है। इसका उपयोग ड्राइवर को गेटकनेक्शन () विधि के लिए कॉल के दौरान ड्राइवर गुण पास करने के लिए किया जाता है।
पिछले उदाहरणों द्वारा किए गए समान कनेक्शन बनाने के लिए, निम्नलिखित कोड का उपयोग करें -
import java.util.*;
String URL = "jdbc:oracle:thin:@amrood:1521:EMP";
Properties info = new Properties( );
info.put( "user", "username" );
info.put( "password", "password" );
Connection conn = DriverManager.getConnection(URL, info);
JDBC कनेक्शन बंद करना
अपने JDBC कार्यक्रम के अंत में, डेटाबेस के प्रत्येक कनेक्शन को समाप्त करने के लिए स्पष्ट रूप से सभी कनेक्शनों को बंद करना आवश्यक है। हालाँकि, यदि आप भूल जाते हैं, तो जावा का कचरा संग्राहक कनेक्शन को बंद कर देगा जब वह बासी वस्तुओं को साफ कर देगा।
कचरा संग्रह पर भरोसा करना, विशेष रूप से डेटाबेस प्रोग्रामिंग में, एक बहुत ही खराब प्रोग्रामिंग अभ्यास है। आपको कनेक्शन ऑब्जेक्ट के साथ हमेशा बंद () विधि के साथ कनेक्शन बंद करने की आदत डालनी चाहिए।
यह सुनिश्चित करने के लिए कि एक कनेक्शन बंद है, आप अपने कोड में एक 'अंत' ब्लॉक प्रदान कर सकते हैं। एक अंततः ब्लॉक हमेशा निष्पादित होता है, भले ही कोई अपवाद हो या न हो।
उपरोक्त खोले गए कनेक्शन को बंद करने के लिए, आपको निम्न प्रकार से कॉल करना चाहिए।
conn.close();
स्पष्ट रूप से एक कनेक्शन को बंद करने से DBMS संसाधनों का संरक्षण होता है, जो आपके डेटाबेस व्यवस्थापक को खुश करेगा।
बेहतर समझ के लिए, हम आपको हमारे JDBC - नमूना कोड ट्यूटोरियल का अध्ययन करने का सुझाव देते हैं ।