जेपीए - ओआरएम घटक

अधिकांश समकालीन अनुप्रयोग डेटा संग्रहीत करने के लिए रिलेशनल डेटाबेस का उपयोग करते हैं। हाल ही में, कई विक्रेताओं ने डेटा रखरखाव पर अपने बोझ को कम करने के लिए ऑब्जेक्ट डेटाबेस पर स्विच किया। इसका मतलब है कि ऑब्जेक्ट डेटाबेस या ऑब्जेक्ट रिलेशनल प्रौद्योगिकियां भंडारण, पुनर्प्राप्ति, अद्यतन और रखरखाव का ध्यान रख रही हैं। इस ऑब्जेक्ट रिलेशनल टेक्नोलॉजीज का मुख्य हिस्सा orm.xml फ़ाइल मैप कर रहा है। जैसा कि xml को संकलन की आवश्यकता नहीं है, हम कम प्रशासन के साथ कई डेटा स्रोतों में आसानी से बदलाव कर सकते हैं।

ऑब्जेक्ट रिलेशनल मैपिंग

ऑब्जेक्ट रिलेशनल मैपिंग (ORM) संक्षेप में आपको बताता है कि ORM क्या है और यह कैसे काम करता है। ORM ऑब्जेक्ट प्रकार से रिलेशनल प्रकार और इसके विपरीत डेटा को गुप्त करने की एक प्रोग्रामिंग क्षमता है।

ओआरएम की मुख्य विशेषता डेटाबेस में अपने डेटा के लिए ऑब्जेक्ट को मैप या बाइंड करना है। मैपिंग करते समय हमें किसी अन्य तालिका में डेटा, उसके प्रकार और उसके स्व-इकाई या इकाई के साथ संबंधों पर विचार करना होगा।

उन्नत सुविधाओं

  • Idiomatic persistence : यह आपको ऑब्जेक्ट ओरिएंटेड कक्षाओं का उपयोग करके दृढ़ता कक्षाएं लिखने में सक्षम बनाता है।

  • High Performance : इसके पास कई लाने की तकनीक और उम्मीद की ताला लगाने की तकनीक है।

  • Reliable: यह अत्यधिक स्थिर और प्रख्यात है। कई औद्योगिक प्रोग्रामर द्वारा उपयोग किया जाता है।

ORM वास्तुकला

यहां ओआरएम वास्तुकला का पालन करें।

उपरोक्त आर्किटेक्चर बताता है कि ऑब्जेक्ट डेटा को तीन चरणों में रिलेशनल डेटाबेस में कैसे संग्रहीत किया जाता है।

चरण 1

पहले चरण को नाम दिया गया Object dataचरण में पीओजेओ कक्षाएं, सेवा इंटरफेस और कक्षाएं शामिल हैं। यह मुख्य व्यवसाय घटक परत है, जिसमें व्यावसायिक तर्क संचालन और विशेषताएं हैं।

उदाहरण के लिए आइए हम स्कीमा के रूप में एक कर्मचारी डेटाबेस लेते हैं-

  • कर्मचारी POJO वर्ग में आईडी, नाम, वेतन और पदनाम जैसी विशेषताएं शामिल हैं। और उन विशेषताओं के सेटर और गेट्टर जैसे तरीके।

  • कर्मचारी DAO / सेवा वर्गों में सेवा के तरीके होते हैं जैसे कि कर्मचारी बनाएं, कर्मचारी खोजें, और कर्मचारी को हटाएं।

2 चरण

दूसरे चरण का नाम mapping या persistence चरण जिसमें JPA प्रदाता, मैपिंग फ़ाइल (ORM.xml), JPA लोडर और ऑब्जेक्ट ग्रिड शामिल हैं।

  • JPA Provider: विक्रेता उत्पाद जिसमें जेपीए स्वाद (javax.persistence) होता है। उदाहरण के लिए एक्लिप्सलिंक, टॉपलिंक, हाइबरनेट आदि।

  • Mapping file : मैपिंग फ़ाइल (ORM.xml) में POJO वर्ग में डेटा और एक संबंधपरक डेटाबेस में डेटा के बीच मैपिंग कॉन्फ़िगरेशन होता है।

  • JPA Loader: जेपीए लोडर कैश मेमोरी की तरह काम करता है, जो रिलेशनल ग्रिड डेटा को लोड कर सकता है। यह POJO डेटा के लिए सेवा वर्गों (POJO वर्ग के गुण) के साथ बातचीत करने के लिए डेटाबेस की एक प्रति की तरह काम करता है।

  • Object Grid: ऑब्जेक्ट ग्रिड एक अस्थायी स्थान है जो रिलेशनल डेटा की कॉपी को कैश मेमोरी की तरह स्टोर कर सकता है। डेटाबेस के खिलाफ सभी प्रश्नों का सबसे पहले ऑब्जेक्ट ग्रिड में डेटा पर असर पड़ता है। इसके प्रतिबद्ध होने के बाद ही, यह मुख्य डेटाबेस को प्रभावित करता है।

चरण 3

तीसरा चरण रिलेशनल डेटा चरण है। इसमें संबंधपरक डेटा होता है जो तार्किक रूप से व्यावसायिक घटक से जुड़ा होता है। जैसा कि ऊपर चर्चा की गई है, केवल जब व्यापार घटक डेटा करता है, तो इसे डेटाबेस में भौतिक रूप से संग्रहीत किया जाता है। तब तक संशोधित डेटा कैश मेमोरी में ग्रिड प्रारूप के रूप में संग्रहीत किया जाता है। वही डेटा प्राप्त करने की प्रक्रिया है।

उपरोक्त तीन चरणों के प्रोग्रामेटिक इंटरैक्शन के तंत्र को ऑब्जेक्ट रिलेशनल मैपिंग कहा जाता है।

Mapping.xml

Mapping.xml फ़ाइल डेटाबेस तालिकाओं के साथ इकाई वर्गों के मानचित्रण के लिए जेपीए विक्रेता को निर्देश देने के लिए है।

आइए हम कर्मचारी इकाई का एक उदाहरण लेते हैं जिसमें चार विशेषताएँ होती हैं। नामित कर्मचारी इकाई का POJO वर्गEmployee.java इस प्रकार है:

public class Employee {

   private int eid;
   private String ename;
   private double salary;
   private String deg;

   public Employee(int eid, String ename, double salary, String deg) {
      super( );
      this.eid = eid;
      this.ename = ename;
      this.salary = salary;
      this.deg = deg;
   }

   public Employee( ) {
      super();
   }

   public int getEid( ) {
      return eid;
   }
   
   public void setEid(int eid) {
      this.eid = eid;
   }
   
   public String getEname( ) {
      return ename;
   }
   
   public void setEname(String ename) {
      this.ename = ename;
   }

   public double getSalary( ) {
      return salary;
   }
   
   public void setSalary(double salary) {
      this.salary = salary;
   }

   public String getDeg( ) {
      return deg;
   }
   
   public void setDeg(String deg) {
      this.deg = deg;
   }
}

उपरोक्त कोड कर्मचारी इकाई POJO वर्ग है। इसमें ईद, एनाम, सैलरी और डाउन जैसी चार खूबियां हैं। इन विशेषताओं पर विचार करें डेटाबेस में तालिका फ़ील्ड हैं और ईद इस तालिका की प्राथमिक कुंजी है। अब हमें इसके लिए हाइबरनेट मैपिंग फाइल डिजाइन करनी होगी। नाम की मैपिंग फ़ाइलmapping.xml इस प्रकार है:

<? xml version="1.0" encoding="UTF-8" ?>

<entity-mappings xmlns="http://java.sun.com/xml/ns/persistence/orm"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="http://java.sun.com/xml/ns/persistence/orm    
   http://java.sun.com/xml/ns/persistence/orm_1_0.xsd"
   version="1.0">
      
   <description> XML Mapping file</description>
      
   <entity class="Employee">        
      <table name="EMPLOYEETABLE"/>
      <attributes>
      
         <id name="eid">
            <generated-value strategy="TABLE"/>
         </id>

         <basic name="ename">
            <column name="EMP_NAME" length="100"/>
         </basic>
         
         <basic name="salary">
         </basic>
         
         <basic name="deg">
         </basic>
         
      </attributes>
   </entity>
   
</entity-mappings>

डेटाबेस तालिका के साथ इकाई वर्ग की मैपिंग के लिए उपरोक्त स्क्रिप्ट। इस फाइल में

  • <entity-mappings> : टैग xml फ़ाइल में इकाई टैग की अनुमति देने के लिए स्कीमा परिभाषा को परिभाषित करता है।

  • <description> : टैग आवेदन के बारे में विवरण को परिभाषित करता है।

  • <entity>: टैग उस इकाई वर्ग को परिभाषित करता है जिसे आप डेटाबेस में तालिका में बदलना चाहते हैं। विशेषता वर्ग POJO इकाई वर्ग नाम को परिभाषित करता है।

  • <table>: टैग तालिका के नाम को परिभाषित करता है। यदि आप वर्ग नाम को तालिका नाम के रूप में रखना चाहते हैं तो यह टैग आवश्यक नहीं है।

  • <attributes> : टैग विशेषताओं (एक तालिका में फ़ील्ड) को परिभाषित करता है।

  • <id>: टैग तालिका की प्राथमिक कुंजी को परिभाषित करता है। <generated-value> टैग परिभाषित करता है कि प्राथमिक कुंजी मान जैसे कि स्वचालित, मैनुअल या अनुक्रम से लिया गया कैसे असाइन किया जाए।

  • <basic> : तालिका के लिए शेष विशेषताओं को परिभाषित करने के लिए टैग का उपयोग किया जाता है।

  • <column-name> : टैग का उपयोग उपयोगकर्ता परिभाषित टेबल फ़ील्ड नाम को परिभाषित करने के लिए किया जाता है।

एनोटेशन

आम तौर पर Xml फाइलें विशिष्ट घटक को कॉन्फ़िगर करने के लिए उपयोग की जाती हैं, या घटकों के दो अलग-अलग विनिर्देशों को मैप करने के लिए। हमारे मामले में, हमें एक फ्रेमवर्क में अलग से xml को बनाए रखना होगा। इसका मतलब है कि मैपिंग xml फ़ाइल लिखते समय हमें mJ.xml फ़ाइल में इकाई टैग के साथ POJO वर्ग विशेषताओं की तुलना करने की आवश्यकता होती है।

यहाँ समाधान है: वर्ग परिभाषा में, हम एनोटेशन का उपयोग करके कॉन्फ़िगरेशन भाग लिख सकते हैं। एनोटेशन का उपयोग वर्गों, गुणों और विधियों के लिए किया जाता है। एनोटेशन की शुरुआत '@' चिन्ह से होती है। वर्ग, संपत्ति या विधि घोषित होने से पहले एनोटेशन घोषित किए जाते हैं। JPA के सभी एनोटेशन javax.persistence पैकेज में परिभाषित किए गए हैं।

हमारे उदाहरणों में प्रयुक्त एनोटेशन की सूची इस प्रकार है

टिप्पणी विवरण
@Entity यह एनोटेशन कक्षा को इकाई या तालिका घोषित करने के लिए निर्दिष्ट करता है।
@Table यह एनोटेशन तालिका नाम घोषित करने के लिए निर्दिष्ट करता है।
@Basic यह एनोटेशन स्पष्ट रूप से गैर बाधा क्षेत्रों को निर्दिष्ट करता है।
@Embedded यह एनोटेशन वर्ग या एक इकाई के गुणों को निर्दिष्ट करता है, जिसका मूल्य उदाहरण एक एम्बेड करने योग्य वर्ग का है।
@Id यह एनोटेशन संपत्ति को निर्दिष्ट करता है, वर्ग की पहचान (तालिका की प्राथमिक कुंजी) के लिए उपयोग करता है।
@GeneratedValue यह एनोटेशन निर्दिष्ट करता है कि कैसे पहचान विशेषता को स्वचालित, मैनुअल या अनुक्रम तालिका से लिया गया मान जैसे आरंभ किया जा सकता है।
@Transient यह एनोटेशन उस संपत्ति को निर्दिष्ट करता है जो लगातार नहीं है अर्थात मान को डेटाबेस में कभी संग्रहीत नहीं किया जाता है।
@Column इस एनोटेशन का उपयोग दृढ़ता या संपत्ति के लिए विशेषता को निर्दिष्ट करने के लिए किया जाता है।
@SequenceGenerator इस एनोटेशन का उपयोग उस संपत्ति के मूल्य को परिभाषित करने के लिए किया जाता है जो @GeneratedValue एनोटेशन में निर्दिष्ट होती है। यह एक अनुक्रम बनाता है।
@TableGenerator इस एनोटेशन का उपयोग @GeneratedValue एनोटेशन में निर्दिष्ट संपत्ति के लिए मूल्य जनरेटर को निर्दिष्ट करने के लिए किया जाता है। यह मूल्य सृजन के लिए एक तालिका बनाता है।
@पहुंच प्रकार इस प्रकार के एनोटेशन का उपयोग एक्सेस प्रकार सेट करने के लिए किया जाता है। अगर आप @AccessType (FIELD) सेट करते हैं तो फ़ील्ड वार एक्सेस हो जाएगा। अगर आप @AccessType (PROPERTY) सेट करते हैं तो संपत्ति वार मूल्यांकन होगा।
@JoinColumn यह एनोटेशन एक इकाई संघ या इकाई संग्रह को निर्दिष्ट करने के लिए उपयोग किया जाता है। यह कई-से-एक और एक-से-कई संघों में उपयोग किया जाता है।
@विशेष बाधा इस एनोटेशन का उपयोग क्षेत्र, प्राथमिक या माध्यमिक तालिका के लिए अद्वितीय बाधा को निर्दिष्ट करने के लिए किया जाता है।
@ColumnResult यह एनोटेशन चुनिंदा खंड का उपयोग करते हुए SQL क्वेरी में एक कॉलम का नाम संदर्भित करता है।
@कई कई इस एनोटेशन का उपयोग जुड़ने वाले टेबल्स के बीच कई-से-कई संबंधों को परिभाषित करने के लिए किया जाता है।
@ManyToOne इस एनोटेशन का उपयोग जॉइन टेबल्स के बीच कई-से-एक संबंधों को परिभाषित करने के लिए किया जाता है।
@अनेको के लिये एक इस एनोटेशन का उपयोग जॉइन टेबल्स के बीच एक-से-कई संबंधों को परिभाषित करने के लिए किया जाता है।
@एक से एक इस एनोटेशन का उपयोग जुड़ने वाले टेबल्स के बीच एक-से-एक संबंध को परिभाषित करने के लिए किया जाता है।
@NamedQueries इस एनोटेशन का उपयोग नामित प्रश्नों की सूची निर्दिष्ट करने के लिए किया जाता है।
@NamedQuery इस एनोटेशन का उपयोग स्थिर नाम का उपयोग करके क्वेरी को निर्दिष्ट करने के लिए किया जाता है।

जावा बीन स्टैंडर्ड

जावा वर्ग, उदाहरण मानों और व्यवहारों को एक एकल इकाई ऑब्जेक्ट में कॉल करता है। जावा बीन एक अस्थायी भंडारण और पुन: प्रयोज्य घटक या एक वस्तु है। यह एक सीरियल करने योग्य वर्ग है जिसमें व्यक्तिगत रूप से इंस्टेंस विशेषताओं को प्रारंभ करने के लिए डिफ़ॉल्ट कंस्ट्रक्टर और गेट्टर और सेटर विधियां हैं।

बीन सम्मेलन

  • बीन में डिफ़ॉल्ट कंस्ट्रक्टर या एक फ़ाइल होती है जिसमें क्रमबद्ध उदाहरण होते हैं। इसलिए, एक सेम बीन को पलटा सकता है।

  • बीन के गुणों को बुलियन गुणों और गैर-बूलियन गुणों में अलग किया जा सकता है।

  • गैर-बूलियन संपत्ति में होता है getter तथा setter तरीकों।

  • बूलियन संपत्ति में होते हैं setter तथा is तरीका।

  • Getterकिसी भी संपत्ति की विधि छोटे अक्षरों में 'get' (जावा विधि सम्मेलन) से शुरू होनी चाहिए और एक फ़ील्ड नाम के साथ जारी रहती है जो कि बड़े अक्षर से शुरू होती है। जैसे कि फ़ील्ड का नाम 'वेतन' है इसलिए इस क्षेत्र की गेट्टर विधि 'getSalary ()' है।

  • Setterकिसी भी संपत्ति की विधि छोटे अक्षर वाले 'सेट' (जावा विधि कन्वेंशन) से शुरू होनी चाहिए, एक फ़ील्ड नाम के साथ जारी रहती है जो कैपिटल लेटर से शुरू होती है और फील्ड में सेट करने के लिए तर्क मूल्य। जैसे फ़ील्ड का नाम 'वेतन' है इसलिए इस क्षेत्र की सेटर विधि 'सेटस्लैरी (डबल सैल)' है।

  • बूलियन संपत्ति के लिए, यह जांचने का तरीका है कि यह सही है या गलत। उदाहरण के लिए, बूलियन संपत्ति 'खाली' है, इस क्षेत्र की विधि 'इस्म खाली ()' है।