JDBC - ड्राइवर के प्रकार
JDBC ड्राइवर क्या है?
JDBC ड्राइवर आपके डेटाबेस सर्वर के साथ बातचीत करने के लिए JDBC API में परिभाषित इंटरफेस को लागू करते हैं।
उदाहरण के लिए, JDBC ड्राइवर का उपयोग करने से आप डेटाबेस कनेक्शन खोल सकते हैं और SQL या डेटाबेस कमांड भेजकर इसके साथ बातचीत कर सकते हैं और फिर जावा के साथ परिणाम प्राप्त कर सकते हैं।
Java.sql पैकेज कि JDK के साथ जहाजों, विभिन्न कक्षाओं में शामिल है के साथ उनके व्यवहार में परिभाषित किया गया है और उनके वास्तविक implementaions तीसरे पक्ष के ड्राइवरों में किया जाता है। थर्ड पार्टी वेंडर अपने डेटाबेस ड्राइवर में java.sql.Driver इंटरफ़ेस लागू करते हैं ।
JDBC ड्राइवर प्रकार
ऑपरेटिंग सिस्टम और हार्डवेयर प्लेटफ़ॉर्म जिसमें जावा संचालित होता है, की विस्तृत विविधता के कारण JDBC ड्राइवर का कार्यान्वयन भिन्न होता है। सूर्य ने कार्यान्वयन के प्रकारों को चार श्रेणियों में विभाजित किया है, प्रकार 1, 2, 3 और 4, जिन्हें नीचे समझाया गया है -
टाइप 1: JDBC-ODBC ब्रिज ड्राइवर
टाइप 1 ड्राइवर में, प्रत्येक क्लाइंट मशीन पर स्थापित ODBC ड्राइवरों तक पहुँचने के लिए JDBC ब्रिज का उपयोग किया जाता है। ODBC का उपयोग करते हुए, आपके सिस्टम पर एक डेटा स्रोत नाम (DSN) को कॉन्फ़िगर करने की आवश्यकता होती है जो लक्ष्य डेटाबेस का प्रतिनिधित्व करता है।
जब जावा पहली बार बाहर आया था, तो यह एक उपयोगी ड्राइवर था क्योंकि अधिकांश डेटाबेस केवल ओडीबीसी एक्सेस का समर्थन करते थे, लेकिन अब इस प्रकार के ड्राइवर की सिफारिश केवल प्रयोगात्मक उपयोग के लिए या जब कोई अन्य विकल्प उपलब्ध नहीं है।
JDBC 1.2 के साथ आने वाला JDBC-ODBC ब्रिज इस तरह के ड्राइवर का एक अच्छा उदाहरण है।
टाइप 2: JDBC- नेटिव एपीआई
टाइप 2 ड्राइवर में, JDBC API कॉल्स को देशी C / C ++ API कॉल में बदल दिया जाता है, जो डेटाबेस के लिए अद्वितीय हैं। ये ड्राइवर आमतौर पर डेटाबेस विक्रेताओं द्वारा प्रदान किए जाते हैं और JDBC-ODBC ब्रिज के समान तरीके से उपयोग किए जाते हैं। विक्रेता-विशिष्ट ड्राइवर को प्रत्येक क्लाइंट मशीन पर स्थापित किया जाना चाहिए।
यदि हम डेटाबेस को बदलते हैं, तो हमें मूल एपीआई को बदलना होगा, क्योंकि यह डेटाबेस के लिए विशिष्ट है और वे अब ज्यादातर अप्रचलित हैं, लेकिन आपको टाइप 2 ड्राइवर के साथ कुछ गति वृद्धि का एहसास हो सकता है, क्योंकि यह ओडीबीसी के ओवरहेड को समाप्त करता है।
ओरेकल कॉल इंटरफ़ेस (OCI) ड्राइवर टाइप 2 ड्राइवर का एक उदाहरण है।
टाइप 3: जेडीबीसी-नेट शुद्ध जावा
टाइप 3 ड्राइवर में, डेटाबेस तक पहुंचने के लिए एक त्रि-स्तरीय दृष्टिकोण का उपयोग किया जाता है। JDBC क्लाइंट एक मिडलवेयर एप्लिकेशन सर्वर के साथ संचार करने के लिए मानक नेटवर्क सॉकेट का उपयोग करते हैं। सॉकेट जानकारी को तब मिडलवेयर एप्लिकेशन सर्वर द्वारा DBMS द्वारा आवश्यक कॉल प्रारूप में अनुवादित किया जाता है, और डेटाबेस सर्वर को अग्रेषित किया जाता है।
इस तरह का ड्राइवर बेहद लचीला होता है, क्योंकि इसके लिए क्लाइंट पर किसी कोड की आवश्यकता नहीं होती है और एक ही ड्राइवर वास्तव में कई डेटाबेस तक पहुंच प्रदान कर सकता है।
आप एप्लिकेशन सर्वर को JDBC "प्रॉक्सी" के रूप में सोच सकते हैं, जिसका अर्थ है कि यह क्लाइंट एप्लिकेशन के लिए कॉल करता है। नतीजतन, आपको इस ड्राइवर प्रकार का प्रभावी ढंग से उपयोग करने के लिए एप्लिकेशन सर्वर के कॉन्फ़िगरेशन के कुछ ज्ञान की आवश्यकता होती है।
आपका एप्लिकेशन सर्वर डेटाबेस से संवाद करने के लिए टाइप 1, 2 या 4 ड्राइवर का उपयोग कर सकता है, बारीकियों को समझना मददगार साबित होगा।
टाइप 4: 100% शुद्ध जावा
टाइप 4 ड्राइवर में, शुद्ध जावा-आधारित ड्राइवर सॉकेट कनेक्शन के माध्यम से सीधे विक्रेता के डेटाबेस के साथ संचार करता है। यह डेटाबेस के लिए उपलब्ध उच्चतम प्रदर्शन ड्राइवर है और आमतौर पर विक्रेता द्वारा ही प्रदान किया जाता है।
इस तरह का ड्राइवर बेहद लचीला है, आपको क्लाइंट या सर्वर पर विशेष सॉफ़्टवेयर स्थापित करने की आवश्यकता नहीं है। इसके अलावा, इन ड्राइवरों को गतिशील रूप से डाउनलोड किया जा सकता है।
MySQL का कनेक्टर / J ड्राइवर एक टाइप 4 ड्राइवर है। अपने नेटवर्क प्रोटोकॉल की मालिकाना प्रकृति के कारण, डेटाबेस विक्रेता आमतौर पर टाइप 4 ड्राइवरों की आपूर्ति करते हैं।
किस ड्राइवर का उपयोग किया जाना चाहिए?
यदि आप Oracle, Sybase, या IBM जैसे डेटाबेस का एक प्रकार एक्सेस कर रहे हैं, तो पसंदीदा ड्राइवर प्रकार 4 है।
यदि आपका जावा एप्लिकेशन एक ही समय में कई प्रकार के डेटाबेस तक पहुंच रहा है, तो टाइप 3 पसंदीदा ड्राइवर है।
टाइप 2 ड्राइवर स्थितियों में उपयोगी होते हैं, जहाँ आपके डेटाबेस के लिए टाइप 3 या टाइप 4 ड्राइवर अभी तक उपलब्ध नहीं है।
टाइप 1 ड्राइवर को परिनियोजन-स्तर ड्राइवर नहीं माना जाता है, और आमतौर पर इसका उपयोग केवल विकास और परीक्षण उद्देश्यों के लिए किया जाता है।