हाइबरनेट - ओआरएम अवलोकन
JDBC क्या है?
JDBC का मतलब है Java Database Connectivity। यह जावा प्रोग्राम से रिलेशनल डेटाबेस तक पहुंचने के लिए जावा एपीआई का एक सेट प्रदान करता है। ये Java API SQL प्रोग्राम को SQL स्टेटमेंट्स को निष्पादित करने और किसी भी SQL कंप्लेंट डेटाबेस के साथ इंटरैक्ट करने में सक्षम बनाता है।
JDBC डेटाबेस को स्वतंत्र अनुप्रयोग लिखने के लिए एक लचीली वास्तुकला प्रदान करता है जो विभिन्न प्लेटफार्मों पर चल सकता है और बिना किसी संशोधन के विभिन्न DBMS के साथ बातचीत कर सकता है।
जेडीबीसी के पेशेवरों और विपक्ष
जेडीबीसी के पेशेवरों | जेडीबीसी के विपक्ष |
---|---|
साफ और सरल एसक्यूएल प्रसंस्करण बड़े डेटा के साथ अच्छा प्रदर्शन छोटे अनुप्रयोगों के लिए बहुत अच्छा है सरल वाक्यविन्यास सीखना आसान है |
जटिल अगर यह बड़ी परियोजनाओं में उपयोग किया जाता है बड़ी प्रोग्रामिंग ओवरहेड कोई एनकैप्सुलेशन नहीं MVC अवधारणा को लागू करने के लिए मुश्किल है क्वेरी DBMS विशिष्ट है |
ऑब्जेक्ट रिलेशनल मैपिंग (ORM) क्यों?
जब हम ऑब्जेक्ट-ओरिएंटेड सिस्टम के साथ काम करते हैं, तो ऑब्जेक्ट मॉडल और रिलेशनल डेटाबेस के बीच एक बेमेल होता है। RDBMS डेटा एक सारणीबद्ध प्रारूप में डेटा का प्रतिनिधित्व करते हैं, जबकि ऑब्जेक्ट-ओरिएंटेड भाषाएँ, जैसे जावा या C # इसे ऑब्जेक्ट्स के इंटरकनेक्टेड ग्राफ़ के रूप में दर्शाती हैं।
निम्न जावा क्लास पर विचार करें जिसमें उचित निर्माता और संबद्ध सार्वजनिक फ़ंक्शन हों -
public class Employee {
private int id;
private String first_name;
private String last_name;
private int salary;
public Employee() {}
public Employee(String fname, String lname, int salary) {
this.first_name = fname;
this.last_name = lname;
this.salary = salary;
}
public int getId() {
return id;
}
public String getFirstName() {
return first_name;
}
public String getLastName() {
return last_name;
}
public int getSalary() {
return salary;
}
}
उपरोक्त वस्तुओं पर विचार करें और उन्हें निम्नलिखित RDBMS तालिका में संग्रहीत और पुनः प्राप्त किया जाना चाहिए -
create table EMPLOYEE (
id INT NOT NULL auto_increment,
first_name VARCHAR(20) default NULL,
last_name VARCHAR(20) default NULL,
salary INT default NULL,
PRIMARY KEY (id)
);
पहली समस्या, क्या होगा अगर हमें कुछ पेज या हमारे एप्लिकेशन विकसित करने के बाद अपने डेटाबेस के डिज़ाइन को संशोधित करने की आवश्यकता है? एक संबंधपरक डेटाबेस में वस्तुओं को लोड करना और संग्रहीत करना, हमें निम्नलिखित पांच बेमेल समस्याओं के लिए उजागर करता है -
अनु क्रमांक। | बेमेल और विवरण |
---|---|
1 | Granularity कभी-कभी आपके पास एक ऑब्जेक्ट मॉडल होगा, जिसमें डेटाबेस में संबंधित तालिकाओं की संख्या से अधिक कक्षाएं होती हैं। |
2 | Inheritance RDBMSs इनहेरिटेंस के समान कुछ भी परिभाषित नहीं करते हैं, जो ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग भाषाओं में एक प्राकृतिक प्रतिमान है। |
3 | Identity RDBMS 'साम्य' की एक धारणा को परिभाषित करता है: प्राथमिक कुंजी। जावा, हालांकि, वस्तु पहचान (ए = बी) और वस्तु समानता (ए। असाल्स (बी)) दोनों को परिभाषित करता है। |
4 | Associations ऑब्जेक्ट-ओरिएंटेड भाषाएं ऑब्जेक्ट संदर्भों का उपयोग करके संघों का प्रतिनिधित्व करती हैं जबकि RDBMS एक विदेशी कुंजी कॉलम के रूप में एक एसोसिएशन का प्रतिनिधित्व करता है। |
5 | Navigation जावा और RDBMS में आप जिस तरह से वस्तुओं तक पहुंचते हैं, वे मौलिक रूप से भिन्न हैं। |
Object-Relational Mअपील (ओआरएम) उपरोक्त सभी बाधा बेमेल को संभालने का उपाय है।
ORM क्या है?
ORM के लिए खड़ा है Object-Relational Mapping (ORM) रिलेशनल डेटाबेस और ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग लैंग्वेज जैसे जावा, C # आदि के बीच डेटा परिवर्तित करने के लिए एक प्रोग्रामिंग तकनीक है।
एक ORM प्रणाली के सादे JDBC पर निम्नलिखित लाभ हैं -
अनु क्रमांक। | लाभ |
---|---|
1 | डीबी टेबल के बजाय व्यापार कोड एक्सेस ऑब्जेक्ट्स को आइए। |
2 | OO तर्क से SQL प्रश्नों का विवरण छुपाता है। |
3 | JDBC के आधार पर 'हुड के तहत।' |
4 | डेटाबेस कार्यान्वयन से निपटने की कोई आवश्यकता नहीं है। |
5 | डेटाबेस संरचना के बजाय व्यावसायिक अवधारणाओं पर आधारित इकाइयाँ। |
6 | लेन-देन प्रबंधन और स्वचालित प्रमुख पीढ़ी। |
7 | अनुप्रयोग का तेजी से विकास। |
एक ORM समाधान में निम्नलिखित चार इकाइयां शामिल हैं -
अनु क्रमांक। | समाधान |
---|---|
1 | एक एपीआई लगातार कक्षाओं की वस्तुओं पर बुनियादी CRUD संचालन करने के लिए। |
2 | वर्गों की संपत्तियों और गुणों को संदर्भित करने वाले प्रश्नों को निर्दिष्ट करने के लिए एक भाषा या एपीआई। |
3 | मैपिंग मेटाडेटा निर्दिष्ट करने के लिए एक विन्यास योग्य सुविधा। |
4 | गंदी जाँच, आलसी एसोसिएशन लाने और अन्य अनुकूलन कार्यों को करने के लिए लेन-देन की वस्तुओं के साथ बातचीत करने की एक तकनीक। |
जावा ओआरएम फ्रेमवर्क
जावा में कई लगातार रूपरेखा और ओआरएम विकल्प हैं। एक सतत ढांचा एक ओआरएम सेवा है जो वस्तुओं को एक संबंधपरक डेटाबेस में संग्रहीत और पुनः प्राप्त करता है।
- एंटरप्राइज़ JavaBeans इकाई बीन्स
- जावा डेटा ऑब्जेक्ट
- Castor
- TopLink
- स्प्रिंग डीएओ
- Hibernate
- और बहुत सारे