जेपीए - त्वरित गाइड

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

आमतौर पर, जावा डेवलपर्स बहुत सारे कोड का उपयोग करते हैं, या डेटाबेस के साथ बातचीत करने के लिए मालिकाना ढांचे का उपयोग करते हैं, जबकि जेपीए का उपयोग करते हुए, डेटाबेस के साथ बातचीत का बोझ काफी कम हो जाता है। यह ऑब्जेक्ट मॉडल (जावा प्रोग्राम) और रिलेशनल मॉडल (डेटाबेस प्रोग्राम) के बीच एक सेतु बनाता है।

संबंधपरक और ऑब्जेक्ट मॉडल के बीच बेमेल

संबंधपरक वस्तुओं को एक सारणीबद्ध प्रारूप में दर्शाया जाता है, जबकि ऑब्जेक्ट मॉडल को वस्तु प्रारूप के एक परस्पर ग्राफ में दर्शाया जाता है। किसी रिलेशनल डेटाबेस से ऑब्जेक्ट मॉडल को संग्रहीत और पुनर्प्राप्त करते समय, कुछ बेमेल निम्न कारणों से होता है:

  • Granularity : ऑब्जेक्ट मॉडल में रिलेशनल मॉडल की तुलना में अधिक ग्रैन्युलैरिटी है।

  • Subtypes : उपप्रकार (वंशानुक्रम का अर्थ है) सभी प्रकार के संबंधपरक डेटाबेस द्वारा समर्थित नहीं हैं।

  • Identity : ऑब्जेक्ट मॉडल की तरह, रिलेशनल मॉडल समानता लिखते समय पहचान को उजागर नहीं करता है।

  • Associations : रिलेशनल मॉडल ऑब्जेक्ट डोमेन मॉडल को देखते हुए कई रिश्तों को निर्धारित नहीं कर सकते हैं।

  • Data navigation : ऑब्जेक्ट मॉडल में ऑब्जेक्ट के बीच डेटा नेविगेशन दोनों मॉडल में अलग है।

जेपीए क्या है?

जावा पर्सिस्टेंस एपीआई कक्षाओं का एक संग्रह है और बड़ी मात्रा में डेटा को लगातार डेटाबेस में संग्रहीत करने के लिए है जो ओरेकल कॉर्पोरेशन द्वारा प्रदान किया जाता है।

JPA का उपयोग कहाँ करें?

रिलेशनल ऑब्जेक्ट मैनेजमेंट के लिए कोड लिखने के बोझ को कम करने के लिए, एक प्रोग्रामर 'जेपीए प्रोवाइडर' फ्रेमवर्क का अनुसरण करता है, जो डेटाबेस के उदाहरण के साथ आसान इंटरैक्शन की अनुमति देता है। यहां जेपीए द्वारा आवश्यक रूपरेखा ली गई है।

जेपीए इतिहास

EJB के पूर्व संस्करण, परिभाषित दृढ़ता परत को javax.ejb.EntityBean इंटरफ़ेस का उपयोग करके व्यावसायिक तर्क परत के साथ जोड़ा गया है।

  • EJB 3.0 की शुरुआत करते समय, दृढ़ता परत को अलग कर दिया गया था और इसे JPA 1.0 (Java Persistence API) के रूप में निर्दिष्ट किया गया था। जेएसआर 220 का उपयोग करके 11 मई 2006 को जेएवी ईई 5 के विनिर्देशों के साथ इस एपीआई के विनिर्देशों को जारी किया गया था।

  • JPA 2.0 को जावा कम्यूनिटी प्रोसेस JSR 317 के एक भाग के रूप में 10 दिसंबर 2009 को JAVA EE6 के विनिर्देशों के साथ जारी किया गया था।

  • JPA 2.1 को JAVA EE7 के विनिर्देश के साथ 22 अप्रैल, 2013 को JSR 338 का उपयोग करके जारी किया गया था।

जेपीए प्रदाता

जेपीए एक खुला स्रोत एपीआई है, इसलिए विभिन्न उद्यम विक्रेता जैसे कि ओरेकल, रेडहैट, एक्लिप्स, आदि जेपीए की दृढ़ता स्वाद को जोड़कर नए उत्पाद प्रदान करते हैं। इनमें से कुछ उत्पादों में शामिल हैं:

Hibernate, Eclipselink, Toplink, Spring Data JPA, etc.

जावा पर्सिस्टेंस एपीआई व्यावसायिक संस्थाओं को संबंधपरक संस्थाओं के रूप में संग्रहीत करने का एक स्रोत है। यह दिखाता है कि एक PLAIN OLD JAVA OBJECT (POJO) को एक इकाई के रूप में कैसे परिभाषित किया जाए और संबंधों के साथ संस्थाओं का प्रबंधन कैसे किया जाए।

कक्षा स्तर की वास्तुकला

निम्न छवि जेपीए के वर्ग स्तर की वास्तुकला को दर्शाती है। यह जेपीए के मुख्य वर्गों और इंटरफेस को दर्शाता है।

निम्न तालिका उपरोक्त वास्तुकला में दिखाए गए प्रत्येक इकाइयों का वर्णन करती है।

इकाइयों विवरण
EntityManagerFactory यह EntityManager का कारखाना वर्ग है। यह कई EntityManager उदाहरण बनाता है और प्रबंधित करता है।
EntityManager यह एक इंटरफ़ेस है, यह वस्तुओं पर दृढ़ता के संचालन का प्रबंधन करता है। यह क्वेरी उदाहरण के लिए कारखाने की तरह काम करता है।
Entity डेटाबेस में रिकॉर्ड्स के रूप में इकाइयां हठ वस्तुओं, भंडार हैं।
EntityTransaction यह EntityManager के साथ एक-से-एक संबंध है। प्रत्येक EntityManager के लिए, EntityTransaction वर्ग द्वारा संचालन बनाए रखा जाता है।
Persistence इस वर्ग में EntityManagerFactory उदाहरण प्राप्त करने के लिए स्थिर तरीके हैं।
Query यह इंटरफ़ेस प्रत्येक जेपीए विक्रेता द्वारा मापदंड से मिलने वाले संबंधपरक वस्तुओं को प्राप्त करने के लिए कार्यान्वित किया जाता है।

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

जेपीए वर्ग संबंध

उपरोक्त वास्तुकला में, कक्षाओं और इंटरफेस के बीच संबंध javax.persistence पैकेज के हैं। निम्नलिखित चित्र उनके बीच के संबंध को दर्शाता है।

  • EntityManagerFactory और EntityManager के बीच संबंध है one-to-many। यह EntityManager उदाहरण के लिए एक कारखाना वर्ग है।

  • EntityManager और EntityTransaction के बीच संबंध है one-to-one। प्रत्येक EntityManager ऑपरेशन के लिए, EntityTransaction उदाहरण है।

  • EntityManager और क्वेरी के बीच संबंध है one-to-many। एक EntityManager उदाहरण का उपयोग करके कई क्वेरीज़ निष्पादित हो सकती हैं।

  • EntityManager और Entity के बीच संबंध है one-to-many। एक EntityManager उदाहरण कई संस्थाओं का प्रबंधन कर सकता है।

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

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

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

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

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

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

  • High Performance : इसमें बहुत सी तकनीकें और आशानुरूप लॉकिंग तकनीकें हैं।

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

ORM वास्तुकला

ORM वास्तुकला इस प्रकार है।

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

चरण 1

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

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

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

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

2 चरण

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

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

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

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

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

चरण 3

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

उपरोक्त तीन चरणों के प्रोग्रामेटिक इंटरैक्शन के तंत्र को कहा जाता है object relational mapping

Mapping.xml

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

आइए हम कर्मचारी इकाई का एक उदाहरण लेते हैं जिसमें चार विशेषताएँ होती हैं। नामित कर्मचारी इकाई का 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 वर्ग है। इसमें चार विशेषताएँ हैंeid, ename, salary, तथा deg। इन विशेषताओं को एक तालिका में तालिका फ़ील्ड के रूप में मानें औरeidइस तालिका की प्राथमिक कुंजी के रूप में। अब हमें इसके लिए हाइबरनेट मैपिंग फाइल डिजाइन करनी होगी। नाम की मैपिंग फ़ाइल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> टैग परिभाषित करता है कि प्राथमिक कुंजी मान कैसे निर्दिष्ट करें Automatic, Manual, या से लिया गया Sequence

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

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

एनोटेशन

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

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

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

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

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

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

बीन सम्मेलन

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

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

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

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

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

  • Setter किसी भी संपत्ति का तरीका छोटे अक्षरों से शुरू होना चाहिए set (जावा विधि सम्मेलन), एक फ़ील्ड नाम के साथ जारी रहा जो कि कैपिटल लेटर और से शुरू होता है argument valueक्षेत्र में जाने के लिए। उदाहरण के लिए, फ़ील्ड का नाम हैsalary इसलिए इस क्षेत्र की सेटर विधि है setSalary ( double sal )

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

यह अध्याय आपको विंडोज और लिनक्स आधारित सिस्टम पर जेपीए स्थापित करने की प्रक्रिया के माध्यम से ले जाता है। किसी भी जटिल सेटअप प्रक्रियाओं के बिना कुछ सरल चरणों का पालन करते हुए जेपीए को आपके वर्तमान जावा वातावरण के साथ आसानी से स्थापित और एकीकृत किया जा सकता है। स्थापना करते समय उपयोगकर्ता प्रशासन की आवश्यकता होती है।

सिस्टम आवश्यकताएं

JDK जावा एसई 2 जेडडीके 1.5 या इसके बाद के संस्करण
याद 1 जीबी रैम (अनुशंसित)
डिस्क में जगह कोई न्यूनतम आवश्यकता नहीं
ऑपरेटिंग सिस्टम संस्करण विंडोज एक्सपी या उससे ऊपर, लिनक्स

आइए अब हम जेपीए को स्थापित करने के चरणों के साथ आगे बढ़ें।

Step1: अपने जावा इंस्टॉलेशन को सत्यापित करें

सबसे पहले, आपको अपने सिस्टम पर जावा सॉफ्टवेयर डेवलपमेंट किट (एसडीके) इंस्टॉल करना होगा। इसे सत्यापित करने के लिए, जिस प्लेटफ़ॉर्म पर आप काम कर रहे हैं, उसके आधार पर निम्नलिखित दो कमांड्स में से किसी को निष्पादित करें।

यदि जावा इंस्टॉलेशन ठीक से किया गया है, तो यह आपके जावा इंस्टॉलेशन के वर्तमान संस्करण और विनिर्देश को प्रदर्शित करेगा। एक नमूना आउटपुट निम्न तालिका में दिया गया है।

मंच आदेश नमूना आउटपुट
खिड़कियाँ

कमांड कंसोल खोलें और टाइप करें:

\>java –version

जावा संस्करण "1.7.0_60"

जावा (टीएम) एसई रन टाइम एनवायरनमेंट (बिल्ड 1.7.0_60-b19)

जावा हॉटस्पॉट (TM) 64-बिट सर्वर VM (24.60-b09, मिश्रित मोड का निर्माण)

लिनक्स

ओपन कमांड टर्मिनल और टाइप करें:

$java –version

जावा संस्करण "1.7.0_25"

ओपन JDK रनटाइम एनवायरनमेंट (rhel-2.3.10.4.el6_4-x86_64)

ओपन JDK 64-बिट सर्वर VM (बिल्ड 23.7-b01, मिश्रित मोड)

  • हम मानते हैं कि इस ट्यूटोरियल के पाठकों के पास अपने सिस्टम पर जावा एसडीके संस्करण 1.7.0_60 है।

  • यदि आपके पास जावा एसडीके नहीं है, तो इसका वर्तमान संस्करण डाउनलोड करें http://www.oracle.com/technetwork/java/javase/downloads/index.html और इसे स्थापित किया है।

चरण 2: अपने जावा पर्यावरण सेट करें

वातावरण चर JAVA_HOME को आधार निर्देशिका स्थान पर इंगित करने के लिए सेट करें जहाँ जावा आपकी मशीन पर स्थापित है। उदाहरण के लिए,

मंच विवरण
खिड़कियाँ JAVA_HOME को C: \ ProgramFiles \ java \ jdk1.7.0_60 पर सेट करें
लिनक्स निर्यात JAVA_HOME = / usr / स्थानीय / जावा-वर्तमान

जावा कंपाइलर स्थान का पूरा पथ सिस्टम पथ में जोड़ें।

मंच विवरण
खिड़कियाँ स्ट्रिंग "C: \ Program Files \ Java \ jdk1.7.0_60 \ bin" सिस्टम चर पथ के अंत में जोड़ें।
लिनक्स निर्यात पथ = $ पथ: $ जाव_होम / बिन /

आदेश निष्पादित करें java -version ऊपर बताए अनुसार कमांड प्रॉम्प्ट से।

चरण 3: जेपीए को स्थापित करना

आप इस ट्यूटोरियल, जैसे कि Eclipselink, हाइबरनेट से किसी भी JPA प्रोवाइडर का उपयोग करके JPA इंस्टॉलेशन के माध्यम से जा सकते हैं। आइए Eclipselink का उपयोग करके JPA इंस्टॉलेशन का पालन करें। जेपीए प्रोग्रामिंग के लिए, हमें विशिष्ट फ़ोल्डर ढांचे का पालन करने की आवश्यकता है, इसलिए आईडीई का उपयोग करना बेहतर है।

लिंक के बाद ग्रहण आईडीई फॉर्म डाउनलोड करें https://www.eclipse.org/downloads/ JavaEE डेवलपर के लिए एक्लिप्साइड चुनें Eclipse indigo

सी ड्राइव में ग्रहण ज़िप फ़ाइल को अनज़िप करें। ग्रहण आईडीई खोलें।

Eclipselink का उपयोग करके JPA स्थापित करना

एक्लिप्सलिंक एक पुस्तकालय है इसलिए हम इसे सीधे ग्रहण आईडीई में नहीं जोड़ सकते। Eclipselink का उपयोग करके जेपीए को स्थापित करने के लिए आपको नीचे दिए गए चरणों का पालन करने की आवश्यकता है।

  • चयन करके एक नया JPA प्रोजेक्ट बनाएं File->New->JPA Project ग्रहण आईडीई में निम्नानुसार है:

  • आपको नाम से एक डायलॉग बॉक्स मिलेगा New JPA Project। प्रोजेक्ट का नाम दर्ज करेंtutorialspoint_JPA_Eclipselink, चेक jre संस्करण और अगला क्लिक करें:

  • उपयोगकर्ता पुस्तकालय अनुभाग में डाउनलोड लाइब्रेरी (यदि आपके पास पुस्तकालय नहीं है) पर क्लिक करें।

  • डाउनलोड लाइब्रेरी संवाद बॉक्स में Eclipselink लाइब्रेरी के नवीनतम संस्करण का चयन करें और निम्नानुसार क्लिक करें:

  • लाइसेंस की शर्तों को स्वीकार करें और डाउनलोड लाइब्रेरी के लिए फिनिश पर क्लिक करें।

  • 6. डाउनलोडिंग शुरू होती है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

  • डाउनलोड करने के बाद, यूजर लाइब्रेरी सेक्शन में डाउनलोड की गई लाइब्रेरी का चयन करें और फिनिश पर क्लिक करें।

  • अंत में आपको प्रोजेक्ट फ़ाइल मिलती है Package Explorerग्रहण आईडीई में। सभी फ़ाइलों को निकालें, आपको निम्नानुसार फ़ोल्डर और फ़ाइल पदानुक्रम मिलेगा:

प्रोजेक्ट में MySQL कनेक्टर जोड़ना

कोई भी उदाहरण जो हम यहां चर्चा करते हैं, उसे डेटाबेस कनेक्टिविटी की आवश्यकता है। आइए डेटाबेस संचालन के लिए MySQL डेटाबेस पर विचार करें। यह जावा प्रोग्राम के साथ बातचीत करने के लिए mysql-कनेक्टर जार की आवश्यकता है।

अपने प्रोजेक्ट में डेटाबेस जार को कॉन्फ़िगर करने के लिए चरणों का पालन करें।

  • प्रोजेक्ट प्रॉपर्टीज पर जाएं ->जावा बिल्ड पाथ राइट राइट क्लिक करके। आपको एक डायलॉग बॉक्स मिलेगा जैसा कि निम्नलिखित स्क्रीन-शॉट में दिखाया गया है। Add External Jars पर क्लिक करें।

  • अपने सिस्टम मेमोरी में जार स्थान पर जाएं, फ़ाइल का चयन करें और खुले पर क्लिक करें।

  • गुण संवाद पर ठीक क्लिक करें। आपको अपने प्रोजेक्ट में MySQL-कनेक्टर जार मिलेगा। अब आप MySQL का उपयोग करके डेटाबेस संचालन करने में सक्षम हैं।

यह अध्याय एक सरल उदाहरण का उपयोग करता है कि जेपीए कैसे काम करता है। आइए हम एक उदाहरण के रूप में कर्मचारी प्रबंधन पर विचार करें। मान लीजिए कि कर्मचारी प्रबंधन किसी कर्मचारी के रिकॉर्ड बनाता है, अपडेट करता है, पाता है और हटाता है। जैसा कि उल्लेख किया गया है, हम डेटाबेस संचालन के लिए MySQL डेटाबेस का उपयोग कर रहे हैं।

इस उदाहरण के मुख्य मॉड्यूल इस प्रकार हैं:

  • Model or POJO

    Employee.java

  • Persistence

    Persistence.xml

  • Service

    CreatingEmployee.java

    UpdatingEmployee.java

    FindingEmployee.java

    DeletingEmployee.java

आइए हम पैकेज पदानुक्रम लेते हैं जिसका उपयोग हमने EPAipselink के साथ JPA इंस्टॉलेशन में किया है। इस उदाहरण के लिए पदानुक्रम का पालन करें जैसा कि नीचे दिखाया गया है:

संस्थाओं का निर्माण

एंटिटी सेम या मॉडल के अलावा और कुछ नहीं हैं। इस उदाहरण में, हम उपयोग करेंगेEmployee एक इकाई के रूप में। eid, ename, salary, तथा degइस इकाई के गुण हैं। इसमें डिफॉल्ट कंस्ट्रक्टर के साथ-साथ सेटर और उन विशेषताओं के गेट्टर मेथड शामिल हैं।

ऊपर दिखाए गए पदानुक्रम में, नाम का एक पैकेज बनाएं ‘com.tutorialspoint.eclipselink.entity’, के अंतर्गत ‘src’(स्रोत) पैकेज। नाम से एक क्लास बनाएंEmployee.java निम्नानुसार पैकेज दिया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;

@Entity
@Table
public class Employee 
{
	@Id
	@GeneratedValue(strategy= GenerationType.AUTO) 	
	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;
	}
	@Override
	public String toString() {
		return "Employee [eid=" + eid + ", ename=" + ename + ", salary="
				+ salary + ", deg=" + deg + "]";
	}
}

उपरोक्त कोड में, हमने इस POJO वर्ग को एक इकाई बनाने के लिए @Entity एनोटेशन का उपयोग किया है।

अगले मॉड्यूल में जाने से पहले हमें रिलेशनल इकाई के लिए डेटाबेस बनाने की आवश्यकता है, जो डेटाबेस को पंजीकृत करेगा persistence.xmlफ़ाइल। MySQL कार्यक्षेत्र खोलें और क्वेरी के बाद hte टाइप करें।

create database jpadb
use jpadb

Persistence.xml

यह मॉड्यूल जेपीए की अवधारणा में एक महत्वपूर्ण भूमिका निभाता है। इस xml फ़ाइल में हम डेटाबेस को पंजीकृत करेंगे और इकाई वर्ग को निर्दिष्ट करेंगे।

ऊपर दिखाए गए पैकेज पदानुक्रम में, JPA सामग्री पैकेज के तहत दृढ़ता, xml इस प्रकार है:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
	<persistence-unit name="Eclipselink_JPA" 
                        transaction-type="RESOURCE_LOCAL">
                         	<class>com.tutorialspoint.eclipselink.entity.Employee</class>
	<properties>
	   <property name="javax.persistence.jdbc.url"
                   value="jdbc:mysql://localhost:3306/jpadb"/>
     	   <property name="javax.persistence.jdbc.user" value="root"/>
	       <property name="javax.persistence.jdbc.password" value="root"/>
	       <property name="javax.persistence.jdbc.driver"
                   value="com.mysql.jdbc.Driver"/>
           <property name="eclipselink.logging.level" value="FINE"/>
	       <property name="eclipselink.ddl-generation" 
		           value="create-tables"/>
	</properties>
	</persistence-unit>
</persistence>

उपरोक्त xml में, <persistence-unit> टैग को जेपीए दृढ़ता के लिए एक विशिष्ट नाम के साथ परिभाषित किया गया है। <class>टैग पैकेज के नाम के साथ इकाई वर्ग को परिभाषित करता है। <properties> टैग सभी गुणों को परिभाषित करता है, और <property>टैग डेटाबेस पंजीकरण, URL विनिर्देश, उपयोगकर्ता नाम और पासवर्ड जैसी प्रत्येक संपत्ति को परिभाषित करता है। ये एक्लिप्सिंक गुण हैं। यह फ़ाइल डेटाबेस को कॉन्फ़िगर करेगी।

दृढ़ता संचालन

एक डेटाबेस के साथ बातचीत के लिए दृढ़ता संचालन का उपयोग किया जाता है और वे हैं load तथा storeसंचालन। एक व्यावसायिक घटक में, सभी दृढ़ता के संचालन सेवा वर्गों के अंतर्गत आते हैं।

ऊपर दिखाए गए पैकेज पदानुक्रम में, नाम का एक पैकेज बनाएं ‘com.tutorialspoint.eclipselink.service’, के अंतर्गत ‘src’(स्रोत) पैकेज। सभी सेवा वर्ग CreateEmloyee.java, UpdateEmployee.java, FindEmployee.java और DeleteEmployee.java के नाम से। इस प्रकार दिए गए पैकेज के अंतर्गत आता है:

कर्मचारी बनाएं

निम्न कोड खंड दिखाता है कि नाम के एक कर्मचारी वर्ग कैसे बनाया जाए CreateEmployee.java

package com.tutorialspoint.eclipselink.service;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.Employee;

public class CreateEmployee 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager( );
		entitymanager.getTransaction( ).begin( );
		
		Employee employee = new Employee( ); 
		employee.setEid( 1201 );
		employee.setEname( "Gopal" );
		employee.setSalary( 40000 );
		employee.setDeg( "Technical Manager" );
		entitymanager.persist( employee );
		entitymanager.getTransaction( ).commit( );
		
		entitymanager.close( );
		emfactory.close( );
	}
}

उपरोक्त कोड में createEntityManagerFactory ()एक ही अद्वितीय नाम प्रदान करके एक दृढ़ता इकाई बनाता है जिसे हम निरंतरता के लिए प्रदान करते हैं। persml.xml फ़ाइल। entitymanagerfactory वस्तु का निर्माण होगा entitymanger का उपयोग करके उदाहरण createEntityManager ()तरीका। entitymanager वस्तु बनाता है entitytransactionलेनदेन प्रबंधन के लिए उदाहरण। का उपयोग करकेentitymanager ऑब्जेक्ट, हम संस्थाओं को डेटाबेस में बनाए रख सकते हैं।

उपरोक्त कार्यक्रम के संकलन और निष्पादन के बाद आपको ग्रहण आईडीई के कंसोल पैनल पर eclipselink लाइब्रेरी से सूचनाएं मिलेंगी।

परिणाम के लिए, MySQL कार्यक्षेत्र खोलें और निम्न क्वेरी टाइप करें।

use jpadb
select * from employee

नामांकित प्रभावी डेटाबेस तालिका employee निम्नानुसार एक सारणीबद्ध प्रारूप में दिखाया जाएगा:

ईद Ename वेतन डिग्री
1201 गोपाल 40000 तकनीक प्रबंधक

कर्मचारी को अपडेट करें

किसी कर्मचारी के रिकॉर्ड को अपडेट करने के लिए, हमें मौजूदा रिकॉर्ड्स को डेटाबेस के रूप में प्राप्त करना होगा, परिवर्तन करना होगा, और अंत में इसे डेटाबेस के लिए प्रतिबद्ध करना होगा। नाम का वर्गUpdateEmployee.java इस प्रकार दिखाया गया है:

package com.tutorialspoint.eclipselink.service;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.Employee;

public class UpdateEmployee 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager( );
				entitymanager.getTransaction( ).begin( );
		Employee employee=entitymanager.
				find( Employee.class, 1201 );
		//before update
		System.out.println( employee );
		employee.setSalary( 46000 );
		entitymanager.getTransaction( ).commit( );
        //after update
		System.out.println( employee );
		entitymanager.close();
		emfactory.close();
	}
}

उपरोक्त कार्यक्रम के संकलन और निष्पादन के बाद आपको ग्रहण IDE के कंसोल पैनल पर Eclipselink लाइब्रेरी से सूचनाएं मिलेंगी।

परिणाम के लिए, MySQL कार्यक्षेत्र खोलें और निम्न क्वेरी टाइप करें।

use jpadb
select * from employee

नामांकित प्रभावी डेटाबेस तालिका employee निम्नानुसार एक सारणीबद्ध प्रारूप में दिखाया जाएगा:

ईद Ename वेतन डिग्री
1201 गोपाल 46000 तकनीक प्रबंधक

कर्मचारी का वेतन, 1201 46000 में अपडेट किया गया है।

कर्मचारी खोजें

किसी कर्मचारी के रिकॉर्ड को खोजने के लिए, हमें डेटाबेस से मौजूदा डेटा को पुनः प्राप्त करना होगा और उसे प्रदर्शित करना होगा। इस ऑपरेशन में, एक रिकॉर्ड प्राप्त करते समय EntityTransaction लागू नहीं किया जाता है।

नाम का वर्ग FindEmployee.java निम्नलिखित नुसार।

package com.tutorialspoint.eclipselink.service;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.Employee;

public class FindEmployee 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence
				.createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager();
		Employee employee = entitymanager.
				find( Employee.class, 1201 );
		
		System.out.println("employee ID = "+employee.getEid( ));
		System.out.println("employee NAME = "+employee.getEname( ));
		System.out.println("employee SALARY = "+employee.getSalary( ));
		System.out.println("employee DESIGNATION = "+employee.getDeg( ));
	}
}

उपरोक्त कार्यक्रम को संकलित और निष्पादित करने के बाद, आप ग्रहण आईडीई के कंसोल पैनल पर एक्लिप्सिंक लाइब्रेरी से निम्न आउटपुट प्राप्त करेंगे।

employee ID = 1201
employee NAME = Gopal
employee SALARY = 46000.0
employee DESIGNATION = Technical Manager

कर्मचारी को हटाना

किसी कर्मचारी के रिकॉर्ड को हटाने के लिए, पहले हम मौजूदा रिकॉर्ड को खोज लेंगे और फिर उसे हटा देंगे। यहाँ EntityTransaction एक महत्वपूर्ण भूमिका निभाता है।

नाम का वर्ग DeleteEmployee.java निम्नलिखित नुसार:

package com.tutorialspoint.eclipselink.service;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.Employee;

public class DeleteEmployee 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager( );
		entitymanager.getTransaction( ).begin( );
		Employee employee=entitymanager.
				find( Employee.class, 1201 );
		entitymanager.remove( employee );
		entitymanager.getTransaction( ).commit( );
		entitymanager.close( );
		emfactory.close( );
	}
}

उपरोक्त कार्यक्रम के संकलन और निष्पादन के बाद आपको ग्रहण IDE के कंसोल पैनल पर Eclipselink लाइब्रेरी से सूचनाएं मिलेंगी।

परिणाम के लिए, MySQL कार्यक्षेत्र खोलें और निम्न क्वेरी टाइप करें।

use jpadb
select * from employee

नामांकित प्रभावी डेटाबेस employee अशक्त रिकॉर्ड होंगे।

इस उदाहरण में सभी मॉड्यूल के पूरा होने के बाद, पैकेज और फ़ाइल पदानुक्रम निम्नानुसार दिखता है:

यह अध्याय JPQL और कैसे यह दृढ़ता इकाइयों के साथ काम करता है के बारे में वर्णन करता है। इस अध्याय में, दिए गए उदाहरण उसी पैकेज पदानुक्रम का पालन करते हैं, जिसका उपयोग हमने पिछले अध्याय में किया था।

जावा दृढ़ता क्वेरी भाषा

JPQL जावा दृढ़ता क्वेरी भाषा के लिए खड़ा है। इसका उपयोग किसी रिलेशनल डेटाबेस में संग्रहीत करने के लिए संस्थाओं के खिलाफ क्वेरी बनाने के लिए किया जाता है। JPQL SQL सिंटैक्स पर आधारित विकसित किया गया है। लेकिन यह सीधे डेटाबेस को प्रभावित नहीं करेगा।

JPQL सेलेक्ट क्लॉज का उपयोग करके डेटा पुनः प्राप्त कर सकता है, UPDATE क्लॉज और DELETE क्लॉज का उपयोग करके बल्क अपडेट कर सकता है।

क्वेरी संरचना

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

उदाहरण के लिए, एक JPQL क्वेरी SQL के साथ के रूप में एक डेटाबेस से निर्धारित क्षेत्र परिणाम के बजाय एक इकाई वस्तु प्राप्त कर सकते हैं। JPQL क्वेरी संरचना निम्नानुसार है।

SELECT ... FROM ...
[WHERE ...]
[GROUP BY ... [HAVING ...]]
[ORDER BY ...]

JPQL DELETE और UPDATE प्रश्नों की संरचना इस प्रकार है।

DELETE FROM ... [WHERE ...]
 
UPDATE ... SET ... [WHERE ...]

स्केलर और सकल कार्य

स्केलर फ़ंक्शन इनपुट मानों के आधार पर परिणामी मान लौटाता है। एकत्रित कार्य इनपुट मानों की गणना करके परिणामी मान लौटाते हैं।

हम पिछले अध्याय के समान कर्मचारी प्रबंधन का उपयोग करेंगे। यहां हम JPQL के स्केलर और एग्रीगेट कार्यों का उपयोग करके सेवा वर्गों के माध्यम से जाएंगे।

हमें मान लेते हैं jpadb.employee तालिका में निम्नलिखित रिकॉर्ड हैं।

ईद Ename वेतन डिग्री
1201 गोपाल 40000 तकनीक प्रबंधक
1202 मनीषा 40000 प्रमाण पाठक
1203 Masthanvali 40000 तकनीकी लेखक
1204 सतीश 30000 तकनीकी लेखक
1205 कृष्णा 30000 तकनीकी लेखक
1206 किरण 35000 प्रमाण पाठक

नाम से एक क्लास बनाएं ScalarandAggregateFunctions.java के अंतर्गत com.tutorialspoint.eclipselink.service पैकेज निम्नानुसार है।

package com.tutorialspoint.eclipselink.service;

import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;

public class ScalarandAggregateFunctions 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager();
		//Scalar function
		Query query = entitymanager.
		createQuery("Select UPPER(e.ename) from Employee e");
		List<String> list=query.getResultList();
		
		for(String e:list)
		{
			System.out.println("Employee NAME :"+e);
		}
		//Aggregate function
		Query query1 = entitymanager.
				createQuery("Select MAX(e.salary) from Employee e");
		Double result=(Double) query1.getSingleResult();
		System.out.println("Max Employee Salary :"+result);
	}
}

उपरोक्त कार्यक्रम के संकलन और निष्पादन के बाद आपको ग्रहण आईडीई के कंसोल पैनल पर निम्न आउटपुट मिलेगा।

Employee NAME :GOPAL
Employee NAME :MANISHA
Employee NAME :MASTHANVALI
Employee NAME :SATISH
Employee NAME :KRISHNA
Employee NAME :KIRAN
ax Employee Salary :40000.0

के बीच, और, कीवर्ड की तरह

Between, And, तथा LikeJPQL के मुख्य कीवर्ड हैं। इन कीवर्ड्स के बाद उपयोग किया जाता हैWhere clause एक प्रश्न में।

नाम से एक क्लास बनाएं BetweenAndLikeFunctions.java के अंतर्गत com.tutorialspoint.eclipselink.service पैकेज निम्नानुसार है:

package com.tutorialspoint.eclipselink.service;

import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
import com.tutorialspoint.eclipselink.entity.Employee;

public class BetweenAndLikeFunctions 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
			createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
			createEntityManager();
		//Between
		Query query = entitymanager.
			createQuery( "Select e " +
					     "from Employee e " +
					     "where e.salary " +
					     "Between 30000 and 40000" )
		List<Employee> list=(List<Employee>)query.getResultList( );
		 
		for( Employee e:list )
		{
			System.out.print("Employee ID :"+e.getEid( ));
			System.out.println("\t Employee salary :"+e.getSalary( ));
		}
		
		//Like
		Query query1 = entitymanager.
			createQuery("Select e " +
					    "from Employee e " +
					    "where e.ename LIKE 'M%'");
		List<Employee> list1=(List<Employee>)query1.getResultList( );
		for( Employee e:list1 )
		{
			System.out.print("Employee ID :"+e.getEid( ));
			System.out.println("\t Employee name :"+e.getEname( ));
		}
	}
}

उपरोक्त कार्यक्रम को संकलित और निष्पादित करने के बाद, आप ग्रहण आईडीई के कंसोल पैनल में निम्नलिखित आउटपुट प्राप्त करेंगे।

Employee ID :1201	 Employee salary :40000.0
Employee ID :1202	 Employee salary :40000.0
Employee ID :1203	 Employee salary :40000.0
Employee ID :1204	 Employee salary :30000.0
Employee ID :1205	 Employee salary :30000.0
Employee ID :1206	 Employee salary :35000.0

Employee ID :1202	 Employee name :Manisha
Employee ID :1203	 Employee name :Masthanvali

आदेश

जेपीक्यूएल में रिकॉर्ड बनाने के लिए, हम ORDER BY क्लॉज का उपयोग करते हैं। इस क्लॉज़ का उपयोग SQL में समान है, लेकिन यह संस्थाओं से संबंधित है। निम्न उदाहरण दिखाता है कि ORDER BY क्लॉज का उपयोग कैसे करें।

एक वर्ग बनाएँ Ordering.java के अंतर्गत com.tutorialspoint.eclipselink.service पैकेज निम्नानुसार है:

package com.tutorialspoint.eclipselink.service;

import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
import com.tutorialspoint.eclipselink.entity.Employee;

public class Ordering 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
			createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
			createEntityManager();
		//Between
		Query query = entitymanager.
			createQuery( "Select e " +
					     "from Employee e " +
					     "ORDER BY e.ename ASC" );
		List<Employee> list=(List<Employee>)query.getResultList( );
		 
		for( Employee e:list )
		{
			System.out.print("Employee ID :"+e.getEid( ));
			System.out.println("\t Employee Name :"+e.getEname( ));
		}
	}
}

उपरोक्त कार्यक्रम को संकलित और निष्पादित करना आप ग्रहण आईडीई के कंसोल पैनल में निम्न आउटपुट का उत्पादन करेंगे।

Employee ID :1201	 Employee Name :Gopal
Employee ID :1206	 Employee Name :Kiran
Employee ID :1205	 Employee Name :Krishna
Employee ID :1202	 Employee Name :Manisha
Employee ID :1203	 Employee Name :Masthanvali
Employee ID :1204	 Employee Name :Satish

नाम दिया गया प्रश्न

एक @NamedQuery एनोटेशन को एक पूर्वनिर्धारित क्वेरी स्ट्रिंग के साथ एक क्वेरी के रूप में परिभाषित किया जाता है जो कि अपरिवर्तनीय है। डायनामिक क्वेरी के विपरीत, नामित क्वेरी POJO से JPQL क्वेरी स्ट्रिंग्स को अलग करके कोड संगठन में सुधार कर सकती है। यह क्वेरी मापदंडों को गतिशील रूप से क्वेरी स्ट्रिंग में एम्बेड करने के बजाय क्वेरी पैरामीटर से गुजरता है और इसलिए अधिक कुशल क्वेरी तैयार करता है।

सबसे पहले, कर्मचारी इकाई वर्ग के नाम पर @NamedQuery एनोटेशन जोड़ें Employee.java के अंतर्गत com.tutorialspoint.eclipselink.entity पैकेज निम्नानुसार है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.NamedQuery;
import javax.persistence.Table;

@Entity
@Table
@NamedQuery(query = "Select e from Employee e where e.eid = :id", 
		name = "find employee by id")
public class Employee 
{
	@Id
	@GeneratedValue(strategy= GenerationType.AUTO) 	
	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;
	}
	@Override
	public String toString() {
		return "Employee [eid=" + eid + ", ename=" + ename + ", salary="
				+ salary + ", deg=" + deg + "]";
	}
}

नाम से एक क्लास बनाएं NamedQueries.java के अंतर्गत com.tutorialspoint.eclipselink.service पैकेज निम्नानुसार है:

package com.tutorialspoint.eclipselink.service;

import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
import com.tutorialspoint.eclipselink.entity.Employee;

public class NamedQueries 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
			createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
			createEntityManager();
		Query query = entitymanager.createNamedQuery(
			"find employee by id");
		query.setParameter("id", 1204);
		List<Employee> list = query.getResultList( );
		for( Employee e:list )
		{
			System.out.print("Employee ID :"+e.getEid( ));
			System.out.println("\t Employee Name :"+e.getEname( ));
		}
	}
}

उपरोक्त कार्यक्रम को संकलित करने और निष्पादित करने के बाद आपको ग्रहण आईडीई के कंसोल पैनल में निम्नलिखित आउटपुट मिलेगा।

Employee ID :1204	 Employee Name :Satish

उपरोक्त सभी वर्गों को जोड़ने के बाद पैकेज पदानुक्रम निम्नानुसार दिखता है:

उत्सुक और आलसी

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

डेटाबेस से रिकॉर्ड लाने के दो तरीके हैं।

उत्सुकता लाने वाला

उत्सुकता से, संबंधित बाल वस्तुओं को एक विशेष रिकॉर्ड प्राप्त करते समय स्वचालित रूप से अपलोड किया जाता है।

आलसी भ्रूण

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

जब आप पहली बार रिकॉर्ड लाने की कोशिश करेंगे तो आलसी भ्रूण संभव है। इस तरह, पूरे रिकॉर्ड की एक प्रतिलिपि पहले से ही कैश मेमोरी में संग्रहीत है। प्रदर्शन के लिहाज से, आलसी भ्रूण बेहतर है।

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

विरासत रणनीतियाँ

वंशानुक्रम किसी भी वस्तु-उन्मुख भाषा की मूल अवधारणा है, इसलिए हम संस्थाओं के बीच विरासत संबंधों या रणनीतियों का उपयोग कर सकते हैं। JPA तीन प्रकार की विरासत रणनीतियों का समर्थन करता है: SINGLE_TABLE, JOINED_TABLE और TABLE_PER_CONCRETE_CLASS।

चलिए, हम एक उदाहरण पर विचार करते हैं। निम्नलिखित आरेख तीन वर्गों को दर्शाता है, अर्थात। स्टाफ़, टीचिंगसैफ्ट, और नॉनचेटिंगशैफ्ट और उनके रिश्ते।

उपरोक्त आरेख में, स्टाफ़ एक इकाई है, जबकि टीचिंगसैफ़्ट और नॉनचेकिंगसॉफ़्ट स्टाफ़ की उप-इकाइयाँ हैं। यहाँ हम विरासत के सभी तीन तीन रणनीतियों को प्रदर्शित करने के लिए उपरोक्त उदाहरण का उपयोग करेंगे।

सिंगल टेबल रणनीति

सिंगल-टेबल रणनीति सभी वर्गों के फ़ील्ड (सुपर और सब क्लास दोनों) को लेती है और उन्हें सिंगल टेबल में शामिल करती है जिसे SINGLE_TABLE रणनीति के रूप में जाना जाता है। यहां एक तालिका में तीन संस्थाओं के मूल्यों को अलग करने में विभेदक मूल्य एक महत्वपूर्ण भूमिका निभाता है।

आइए उपरोक्त उदाहरण पर विचार करें। TeachingStaff और NonTeachingStaff, उप-वर्ग के कर्मचारी हैं। विरासत की अवधारणा के अनुसार, एक उप-वर्ग अपने सुपर-क्लास के गुणों को विरासत में लेता है। इसलिए sid और sname ऐसे फील्ड हैं जो टीचिंगसैफ्ट और नॉनटचिंगसैफ्ट दोनों से संबंधित हैं। एक JPA प्रोजेक्ट बनाएं। इस परियोजना के सभी मॉड्यूल निम्नानुसार हैं:

संस्थाओं का निर्माण

नाम का पैकेज बनाएं ‘com.tutorialspoint.eclipselink.entity’ के अंतर्गत ‘src’पैकेज। नाम से एक नया जावा क्लास बनाएंStaff.javaदिए गए पैकेज के तहत। कर्मचारी इकाई वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import java.io.Serializable;
import javax.persistence.DiscriminatorColumn;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.InheritanceType;
import javax.persistence.Table;
@Entity
@Table
@Inheritance( strategy = InheritanceType.SINGLE_TABLE )
@DiscriminatorColumn( name="type" )
public class Staff implements Serializable 
{
	@Id
	@GeneratedValue( strategy = GenerationType.AUTO )
	private int sid;
	private String sname;
	public Staff( int sid, String sname ) 
	{
		super( );
		this.sid = sid;
		this.sname = sname;
	}
	public Staff( ) 
	{
		super( );
	}
	public int getSid( ) 
	{
		return sid;
	}
	public void setSid( int sid ) 
	{
		this.sid = sid;
	}
	public String getSname( ) 
	{
		return sname;
	}
	public void setSname( String sname ) 
	{
		this.sname = sname;
	}
}

उपरोक्त कोड में @DescriminatorColumn फ़ील्ड नाम निर्दिष्ट करता है (type) और इसके मान शेष (टीचिंग और नॉन-टीचिंगसैफ्ट) फ़ील्ड दिखाते हैं।

नामित स्टाफ वर्ग के लिए एक उपवर्ग (वर्ग) बनाएँ TeachingStaff.java के नीचे com.tutorialspoint.eclipselink.entityपैकेज। TeachingStaff Entity वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.DiscriminatorValue;
import javax.persistence.Entity;

@Entity
@DiscriminatorValue( value="TS" )
public class TeachingStaff extends Staff 
{
	private String qualification;
	private String subjectexpertise;
	
	public TeachingStaff( int sid, String sname, 
			String qualification,String subjectexpertise ) 
	{
		super( sid, sname );
		this.qualification = qualification;
		this.subjectexpertise = subjectexpertise;
	}
	
	public TeachingStaff( ) 
	{
		super( );
	}

	public String getQualification( )
	{
		return qualification;
	}

	public void setQualification( String qualification )
	{
		this.qualification = qualification;
	}

	public String getSubjectexpertise( ) 
	{
		return subjectexpertise;
	}

	public void setSubjectexpertise( String subjectexpertise )
	{
		this.subjectexpertise = subjectexpertise;
	}
}

नामित स्टाफ वर्ग के लिए एक उपवर्ग (वर्ग) बनाएँ NonTeachingStaff.java के नीचे com.tutorialspoint.eclipselink.entityपैकेज। NonTeachingStaff इकाई वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.DiscriminatorValue;
import javax.persistence.Entity;

@Entity
@DiscriminatorValue( value = "NS" )
public class NonTeachingStaff extends Staff 
{
	private String areaexpertise;

	public NonTeachingStaff( int sid, String sname, 
			String areaexpertise ) 
	{
		super( sid, sname );
		this.areaexpertise = areaexpertise;
	}

	public NonTeachingStaff( ) 
	{
		super( );
	}

	public String getAreaexpertise( ) 
	{
		return areaexpertise;
	}

	public void setAreaexpertise( String areaexpertise )
	{
		this.areaexpertise = areaexpertise;
	}
}

Persistence.xml

Persistence.xml में डेटाबेस की कॉन्फ़िगरेशन जानकारी और निकाय कक्षाओं की पंजीकरण जानकारी शामिल होती है। Xml फ़ाइल निम्नानुसार दिखाई गई है:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
	<persistence-unit name="Eclipselink_JPA" 
                        transaction-type="RESOURCE_LOCAL">
	    <class>com.tutorialspoint.eclipselink.entity.Staff</class>
		<class>com.tutorialspoint.eclipselink.entity.NonTeachingStaff</class>
		<class>com.tutorialspoint.eclipselink.entity.TeachingStaff</class>
		<properties>
			<property name="javax.persistence.jdbc.url" 
                            value="jdbc:mysql://localhost:3306/jpadb"/>
			<property name="javax.persistence.jdbc.user" value="root"/>
			<property name="javax.persistence.jdbc.password" 
                            value="root"/>
			<property name="javax.persistence.jdbc.driver" 
                            value="com.mysql.jdbc.Driver"/>
			<property name="eclipselink.logging.level" value="FINE"/>
			<property name="eclipselink.ddl-generation" 
                            value="create-tables"/>
		</properties>
	</persistence-unit>
</persistence>

सेवा वर्ग

सेवा वर्ग व्यवसाय घटक का कार्यान्वयन हिस्सा हैं। के तहत एक पैकेज बनाएं‘src’ पैकेज का नाम ‘com.tutorialspoint.eclipselink.service’

नाम से एक क्लास बनाएं SaveClient.javaदिए गए पैकेज के तहत स्टाफ, टीचिंगसैफ्ट और नॉनटचिंगसॉफ्ट क्लास फील्ड को स्टोर करने के लिए। SaveClient वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.service;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.NonTeachingStaff;
import com.tutorialspoint.eclipselink.entity.TeachingStaff;

public class SaveClient 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager( );
		entitymanager.getTransaction( ).begin( );
		
		//Teaching staff entity 
		TeachingStaff ts1=new TeachingStaff(
				1,"Gopal","MSc MEd","Maths");
		TeachingStaff ts2=new TeachingStaff(
				2, "Manisha", "BSc BEd", "English");
		//Non-Teaching Staff entity
		NonTeachingStaff nts1=new NonTeachingStaff(
				3, "Satish", "Accounts");
		NonTeachingStaff nts2=new NonTeachingStaff(
				4, "Krishna", "Office Admin");
		
		//storing all entities
		entitymanager.persist(ts1);
		entitymanager.persist(ts2);
		entitymanager.persist(nts1);
		entitymanager.persist(nts2);
		entitymanager.getTransaction().commit();
		entitymanager.close();
		emfactory.close();
	}
}

उपरोक्त कार्यक्रम को संकलित करने और निष्पादित करने के बाद, आपको ग्रहण आईडीई के कंसोल पैनल पर सूचनाएं मिलेंगी। आउटपुट के लिए MySQL कार्यक्षेत्र की जाँच करें। एक सारणीबद्ध प्रारूप में आउटपुट निम्नानुसार दिखाया गया है:

सिड प्रकार SNAME Areaexpertise योग्यता Subjectexpertise
1 टी गोपाल एमएससी मेड गणित
2 टी मनीषा BSC BED अंग्रेज़ी
3 एन एस सतीश हिसाब किताब
4 एन एस कृष्णा कार्यालय व्यवस्थापक

अंत में आपको एक एकल तालिका मिलेगी जिसमें तीनों वर्गों के क्षेत्र में एक विभेदक कॉलम नाम दिया गया है Type (मैदान)।

टेबल रणनीति में शामिल हो गए

शामिल तालिका की रणनीति संदर्भित स्तंभ को साझा करने के लिए है जिसमें तालिका में शामिल होने और आसान लेनदेन करने के लिए अद्वितीय मूल्य शामिल हैं। हमें ऊपर के रूप में एक ही उदाहरण पर विचार करें।

एक JPA प्रोजेक्ट बनाएं। सभी परियोजना मॉड्यूल नीचे दिखाए गए हैं।

संस्थाओं का निर्माण

नाम का पैकेज बनाएं ‘com.tutorialspoint.eclipselink.entity’ के अंतर्गत ‘src’पैकेज। नाम से एक नया जावा क्लास बनाएंStaff.javaदिए गए पैकेज के तहत। कर्मचारी इकाई वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import java.io.Serializable;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.InheritanceType;
import javax.persistence.Table;

@Entity
@Table
@Inheritance( strategy = InheritanceType.JOINED )
public class Staff implements Serializable 
{
	@Id
	@GeneratedValue( strategy = GenerationType.AUTO )
	private int sid;
	private String sname;
	public Staff( int sid, String sname ) 
	{
		super( );
		this.sid = sid;
		this.sname = sname;
	}
	public Staff( ) 
	{
		super( );
	}
	public int getSid( ) 
	{
		return sid;
	}
	public void setSid( int sid ) 
	{
		this.sid = sid;
	}
	public String getSname( ) 
	{
		return sname;
	}
	public void setSname( String sname ) 
	{
		this.sname = sname;
	}
}

नामित स्टाफ वर्ग के लिए एक उपवर्ग (वर्ग) बनाएँ TeachingStaff.java के नीचे com.tutorialspoint.eclipselink.entityपैकेज। TeachingStaff Entity वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.DiscriminatorValue;
import javax.persistence.Entity;

@Entity
@PrimaryKeyJoinColumn(referencedColumnName="sid")
public class TeachingStaff extends Staff 
{
	private String qualification;
	private String subjectexpertise;
	
	public TeachingStaff( int sid, String sname, 
			String qualification,String subjectexpertise ) 
	{
		super( sid, sname );
		this.qualification = qualification;
		this.subjectexpertise = subjectexpertise;
	}
	
	public TeachingStaff( ) 
	{
		super( );
		
	}

	public String getQualification( )
	{
		return qualification;
	}

	public void setQualification( String qualification )
	{
		this.qualification = qualification;
	}

	public String getSubjectexpertise( ) 
	{
		return subjectexpertise;
	}

	public void setSubjectexpertise( String subjectexpertise )
	{
		this.subjectexpertise = subjectexpertise;
	}
}

नामित स्टाफ वर्ग के लिए एक उपवर्ग (वर्ग) बनाएँ NonTeachingStaff.java के नीचे com.tutorialspoint.eclipselink.entityपैकेज। NonTeachingStaff इकाई वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.DiscriminatorValue;
import javax.persistence.Entity;

@Entity
@PrimaryKeyJoinColumn(referencedColumnName="sid")
public class NonTeachingStaff extends Staff 
{
	private String areaexpertise;

	public NonTeachingStaff( int sid, String sname, 
			String areaexpertise ) 
	{
		super( sid, sname );
		this.areaexpertise = areaexpertise;
	}

	public NonTeachingStaff( ) 
	{
		super( );
	}

	public String getAreaexpertise( ) 
	{
		return areaexpertise;
	}

	public void setAreaexpertise( String areaexpertise )
	{
		this.areaexpertise = areaexpertise;
	}
}

Persistence.xml

Persistence.xml फ़ाइल में डेटाबेस की कॉन्फ़िगरेशन जानकारी और निकाय कक्षाओं की पंजीकरण जानकारी होती है। Xml फ़ाइल निम्नानुसार दिखाई गई है:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
	<persistence-unit name="Eclipselink_JPA" 
                        transaction-type="RESOURCE_LOCAL">
	<class>com.tutorialspoint.eclipselink.entity.Staff</class>
	<class>com.tutorialspoint.eclipselink.entity.NonTeachingStaff</class>
	<class>com.tutorialspoint.eclipselink.entity.TeachingStaff</class>
		<properties>
			<property name="javax.persistence.jdbc.url" 
                            value="jdbc:mysql://localhost:3306/jpadb"/>
			<property name="javax.persistence.jdbc.user" value="root"/>
			<property name="javax.persistence.jdbc.password" 
                            value="root"/>
			<property name="javax.persistence.jdbc.driver" 
                            value="com.mysql.jdbc.Driver"/>
			<property name="eclipselink.logging.level" value="FINE"/>
			<property name="eclipselink.ddl-generation" 
                            value="create-tables"/>
		</properties>
	</persistence-unit>
</persistence>

सेवा वर्ग

सेवा वर्ग व्यवसाय घटक का कार्यान्वयन हिस्सा हैं। के तहत एक पैकेज बनाएं‘src’ पैकेज का नाम ‘com.tutorialspoint.eclipselink.service’

नाम से एक क्लास बनाएं SaveClient.javaदिए गए पैकेज के तहत स्टॉफ, टीचिंगसैफ्ट और नॉनटचिंगसैफ्ट क्लास के फील्ड को स्टोर करने के लिए। तब SaveClient वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.service;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.NonTeachingStaff;
import com.tutorialspoint.eclipselink.entity.TeachingStaff;

public class SaveClient 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager( );
		entitymanager.getTransaction( ).begin( );
		
		//Teaching staff entity 
		TeachingStaff ts1=new TeachingStaff(
				1,"Gopal","MSc MEd","Maths");
		TeachingStaff ts2=new TeachingStaff(
				2, "Manisha", "BSc BEd", "English");
		//Non-Teaching Staff entity
		NonTeachingStaff nts1=new NonTeachingStaff(
				3, "Satish", "Accounts");
		NonTeachingStaff nts2=new NonTeachingStaff(
		4, "Krishna", "Office Admin");
		
		//storing all entities
		entitymanager.persist(ts1);
		entitymanager.persist(ts2);
		entitymanager.persist(nts1);
		entitymanager.persist(nts2);
		
		entitymanager.getTransaction().commit();
		entitymanager.close();
		emfactory.close();
	}
}

उपरोक्त कार्यक्रम को संकलित करने और निष्पादित करने के बाद, आपको ग्रहण आईडीई के कंसोल पैनल में सूचनाएं मिलेंगी। आउटपुट के लिए, MySQL कार्यक्षेत्र की जाँच करें।

यहां तीन टेबल बनाए गए हैं और इनका परिणाम है staff तालिका एक सारणीबद्ध प्रारूप में प्रदर्शित होती है।

सिड Dtype SNAME
1 शिक्षण स्टाफ गोपाल
2 शिक्षण स्टाफ मनीषा
3 NonTeachingStaff सतीश
4 NonTeachingStaff कृष्णा

का परिणाम TeachingStaff तालिका निम्नानुसार प्रदर्शित की गई है:

सिड योग्यता Subjectexpertise
1 एमएससी मेड गणित
2 BSC BED अंग्रेज़ी

उपरोक्त टेबल साइड में विदेशी की (संदर्भ क्षेत्र प्रपत्र स्टाफ टेबल) का परिणाम है NonTeachingStaff तालिका निम्नानुसार प्रदर्शित की गई है:

सिड Areaexpertise
3 हिसाब किताब
4 कार्यालय व्यवस्थापक

अंत में, तीन तालिकाओं को उनके संबंधित क्षेत्रों का उपयोग करके बनाया जाता है और SID क्षेत्र को तीनों तालिकाओं द्वारा साझा किया जाता है। स्टाफ तालिका में, SID प्राथमिक कुंजी है। शेष दो तालिकाओं (टीचिंगसैफ्ट और नॉनटचिंगसैफ्ट) में, SID विदेशी कुंजी है।

कक्षा प्रति रणनीति

प्रति वर्ग रणनीति तालिका प्रत्येक उप-इकाई के लिए एक तालिका बनाना है। स्टाफ टेबल बनाई जाएगी, लेकिन इसमें शून्य मान होंगे। स्टाफ़ टेबल के फील्ड मानों को टीचिंगसैफ्ट और नॉन-टीचिंगसैफ्ट टेबल दोनों द्वारा साझा किया जाना चाहिए।

हमें ऊपर के रूप में एक ही उदाहरण पर विचार करें।

संस्थाओं का निर्माण

नाम का पैकेज बनाएं ‘com.tutorialspoint.eclipselink.entity’ के अंतर्गत ‘src’पैकेज। नाम से एक नया जावा क्लास बनाएंStaff.javaदिए गए पैकेज के तहत। कर्मचारी इकाई वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import java.io.Serializable;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.InheritanceType;
import javax.persistence.Table;

@Entity
@Table
@Inheritance( strategy = InheritanceType.TABLE_PER_CLASS )
public class Staff implements Serializable 
{
	@Id
	@GeneratedValue( strategy = GenerationType.AUTO )
	private int sid;
	private String sname;
	public Staff( int sid, String sname ) 
	{
		super( );
		this.sid = sid;
		this.sname = sname;
	}
	public Staff( ) 
	{
		super( );
	}
	public int getSid( ) 
	{
		return sid;
	}
	public void setSid( int sid ) 
	{
		this.sid = sid;
	}
	public String getSname( ) 
	{
		return sname;
	}
	public void setSname( String sname ) 
	{
		this.sname = sname;
	}
}

नामित स्टाफ वर्ग के लिए एक उपवर्ग (वर्ग) बनाएँ TeachingStaff.java के नीचे com.tutorialspoint.eclipselink.entityपैकेज। TeachingStaff Entity वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.DiscriminatorValue;
import javax.persistence.Entity;

@Entity
public class TeachingStaff extends Staff 
{
	private String qualification;
	private String subjectexpertise;
	
	public TeachingStaff( int sid, String sname, 
			String qualification,String subjectexpertise ) 
	{
		super( sid, sname );
		this.qualification = qualification;
		this.subjectexpertise = subjectexpertise;
	}
	
	public TeachingStaff( ) 
	{
		super( );
		
	}

	public String getQualification( )
	{
		return qualification;
	}
	public void setQualification( String qualification )
	{
		this.qualification = qualification;
	}

	public String getSubjectexpertise( ) 
	{
		return subjectexpertise;
	}

	public void setSubjectexpertise( String subjectexpertise )
	{
		this.subjectexpertise = subjectexpertise;
	}
}

नामित स्टाफ वर्ग के लिए एक उपवर्ग (वर्ग) बनाएँ NonTeachingStaff.java के नीचे com.tutorialspoint.eclipselink.entityपैकेज। NonTeachingStaff इकाई वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.DiscriminatorValue;
import javax.persistence.Entity;

@Entity
public class NonTeachingStaff extends Staff 
{
	private String areaexpertise;

	public NonTeachingStaff( int sid, String sname, 
			String areaexpertise )
			{
		super( sid, sname );
		this.areaexpertise = areaexpertise;
	}

	public NonTeachingStaff( ) 
	{
		super( );
	}

	public String getAreaexpertise( ) 
	{
		return areaexpertise;
	}

	public void setAreaexpertise( String areaexpertise )
	{
		this.areaexpertise = areaexpertise;
	}
}

Persistence.xml

Persistence.xml फ़ाइल में डेटाबेस कक्षाओं की कॉन्फ़िगरेशन जानकारी और निकाय कक्षाओं की पंजीकरण जानकारी होती है। Xml फ़ाइल निम्नानुसार दिखाई गई है:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
	<persistence-unit name="Eclipselink_JPA" 
                        transaction-type="RESOURCE_LOCAL">
	<class>com.tutorialspoint.eclipselink.entity.Staff</class>
	<class>com.tutorialspoint.eclipselink.entity.NonTeachingStaff</class>
	<class>com.tutorialspoint.eclipselink.entity.TeachingStaff</class>
		<properties>
			<property name="javax.persistence.jdbc.url" 
                            value="jdbc:mysql://localhost:3306/jpadb"/>
			<property name="javax.persistence.jdbc.user" value="root"/>
			<property name="javax.persistence.jdbc.password" 
                            value="root"/>
			<property name="javax.persistence.jdbc.driver" 
                            value="com.mysql.jdbc.Driver"/>
			<property name="eclipselink.logging.level" value="FINE"/>
			<property name="eclipselink.ddl-generation" 
                            value="create-tables"/>
			</properties>
	</persistence-unit>
</persistence>

सेवा वर्ग

सेवा वर्ग व्यवसाय घटक का कार्यान्वयन हिस्सा हैं। के तहत एक पैकेज बनाएं‘src’ पैकेज का नाम ‘com.tutorialspoint.eclipselink.service’

नाम से एक क्लास बनाएं SaveClient.javaदिए गए पैकेज के तहत स्टाफ, टीचिंगसैफ्ट और नॉनटचिंगसॉफ्ट क्लास फील्ड को स्टोर करने के लिए। SaveClient वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.service;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.NonTeachingStaff;
import com.tutorialspoint.eclipselink.entity.TeachingStaff;
public class SaveClient 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager( );
		entitymanager.getTransaction( ).begin( );
		
		//Teaching staff entity 
		TeachingStaff ts1=new TeachingStaff(
				1,"Gopal","MSc MEd","Maths");
		TeachingStaff ts2=new TeachingStaff(
				2, "Manisha", "BSc BEd", "English");
		//Non-Teaching Staff entity
		NonTeachingStaff nts1=new NonTeachingStaff(
				3, "Satish", "Accounts");
		NonTeachingStaff nts2=new NonTeachingStaff(
				4, "Krishna", "Office Admin");
		
		//storing all entities
		entitymanager.persist(ts1);
		entitymanager.persist(ts2);
		entitymanager.persist(nts1);
		entitymanager.persist(nts2);
		
		entitymanager.getTransaction().commit();
		entitymanager.close();
		emfactory.close();
	}
}

उपरोक्त कार्यक्रम को संकलित और निष्पादित करने के बाद, आपको ग्रहण आईडीई के कंसोल पैनल पर सूचनाएं मिलेंगी। आउटपुट के लिए, MySQL कार्यक्षेत्र की जाँच करें।

यहां तीन टेबल बनाए गए हैं और Staff तालिका में अशक्त रिकॉर्ड हैं।

का परिणाम TeachingStaff इस प्रकार प्रदर्शित किया जाता है:

सिड योग्यता SNAME Subjectexpertise
1 एमएससी मेड गोपाल गणित
2 BSC BED मनीषा अंग्रेज़ी

ऊपर दी गई तालिका टीचिंगसैफ्ट में स्टाफ और टीचिंगसैफ्ट दोनों संस्थाओं के क्षेत्र शामिल हैं।

का परिणाम NonTeachingStaff इस प्रकार प्रदर्शित किया जाता है:

सिड Areaexpertise SNAME
3 हिसाब किताब सतीश
4 कार्यालय व्यवस्थापक कृष्णा

उपरोक्त तालिका में NonTeachingStaff में स्टाफ और NonTeachingStaff दोनों प्रकार के क्षेत्र शामिल हैं।

यह अध्याय आपको संस्थाओं के बीच संबंधों के माध्यम से ले जाता है। आमतौर पर डेटाबेस में तालिकाओं के बीच संबंध अधिक प्रभावी होते हैं। यहां इकाई वर्गों को संबंधपरक तालिकाओं (JPA की अवधारणा) के रूप में माना जाता है, इसलिए इकाई वर्गों के बीच संबंध निम्नानुसार हैं:

  • @ManyToOne संबंध
  • @OneToMany संबंध
  • @OneToOne संबंध
  • @ManyToMany संबंध

@ManyToOne संबंध

संस्थाओं के बीच कई-टू-वन संबंध मौजूद है जहां एक इकाई (स्तंभों या स्तंभों) को किसी अन्य इकाई (स्तंभों के स्तंभ या सेट) के साथ संदर्भित किया जाता है जिसमें अद्वितीय मान होते हैं। संबंधपरक डेटाबेस में, इन संबंधों को तालिकाओं के बीच विदेशी कुंजी / प्राथमिक कुंजी का उपयोग करके लागू किया जाता है।

आइए हम कर्मचारी और विभाग संस्थाओं के बीच संबंध के उदाहरण पर विचार करें। यूनिडायरेक्शनल तरीके से, यानी, कर्मचारी से विभाग तक, कई-से-एक संबंध लागू होता है। इसका मतलब है कि कर्मचारी के प्रत्येक रिकॉर्ड में एक विभाग आईडी होता है, जो विभाग की तालिका में एक प्राथमिक कुंजी होना चाहिए। यहां कर्मचारी तालिका में, विभाग आईडी विदेशी कुंजी है।

निम्न आरेख दो तालिकाओं के बीच कई-से-एक संबंध दिखाता है।

नामांकित ग्रहण आईडीई में एक जेपीए परियोजना बनाएं JPA_Eclipselink_MTO। इस परियोजना के सभी मॉड्यूल नीचे चर्चा कर रहे हैं।

संस्थाओं का निर्माण

संस्थाएँ बनाने के लिए ऊपर दिए गए आरेख का पालन करें। नाम का पैकेज बनाएं‘com.tutorialspoin.eclipselink.entity’ के अंतर्गत ‘src’पैकेज। नाम से एक क्लास बनाएंDepartment.javaदिए गए पैकेज के तहत। वर्ग विभाग इकाई को निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class Department 
{
    @Id 
    @GeneratedValue( strategy=GenerationType.AUTO )
    private int id;
    private String name;

    public int getId() 
    {
    	return id;
    }
    
    public void setId(int id) 
    {
    	this.id = id;
    }
    
    public String getName( )
    {
    	return name;
    }
    
    public void setName( String deptName )
    {
    	this.name = deptName;
    }
}

इस संबंध में दूसरी इकाई बनाएँ - कर्मचारी इकाई नाम Employee.java के अंतर्गत ‘com.tutorialspoint.eclipselink.entity’पैकेज। कर्मचारी इकाई वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.ManyToOne;

@Entity
public class Employee 
{
	@Id
	@GeneratedValue( strategy= GenerationType.AUTO ) 	
	private int eid;
	private String ename;
	private double salary;
	private String deg;
	@ManyToOne
	private Department department;
	
	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;
	}
		
	public Department getDepartment() {
		return department;
	}

	public void setDepartment(Department department) {
		this.department = department;
	}
}

Persistence.xml

Persistence.xml फ़ाइल को डेटाबेस और इकाई वर्गों के पंजीकरण को कॉन्फ़िगर करने के लिए आवश्यक है।

Persitence.xml JPA प्रोजेक्ट बनाते समय ग्रहण IDE द्वारा बनाया जाएगा। कॉन्फ़िगरेशन विवरण उपयोगकर्ता के विनिर्देश हैं। दृढ़ता। Xml फ़ाइल निम्नानुसार दिखाई गई है:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" 
             xmlns="http://java.sun.com/xml/ns/persistence" 
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
             xsi:schemaLocation="http://java.sun.com/xml/ns/persistence 
             http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
	<persistence-unit name="Eclipselink_JPA" 
                        transaction-type="RESOURCE_LOCAL">
	<class>com.tutorialspoint.eclipselink.entity.Employee</class>
	<class>com.tutorialspoint.eclipselink.entity.Department</class>
		<properties>
			<property name="javax.persistence.jdbc.url" 
			          value="jdbc:mysql://localhost:3306/jpadb"/>
			<property name="javax.persistence.jdbc.user" value="root"/>
			<property name="javax.persistence.jdbc.password"
                            value="root"/>
			<property name="javax.persistence.jdbc.driver" 
			          value="com.mysql.jdbc.Driver"/>
			<property name="eclipselink.logging.level" value="FINE"/>
			<property name="eclipselink.ddl-generation" 
			          value="create-tables"/>
		</properties>
	</persistence-unit>
</persistence>

सेवा वर्ग

इस मॉड्यूल में सेवा वर्ग शामिल हैं, जो विशेषता आरंभीकरण का उपयोग करके रिलेशनल भाग को लागू करता है। के तहत एक पैकेज बनाएं‘src’ पैकेज का नाम ‘com.tutorialspoint.eclipselink.service’। नाम दिया गया DAO वर्गManyToOne.javaदिए गए पैकेज के तहत बनाया गया है। DAO वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspointeclipselink.service;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.Department;
import com.tutorialspoint.eclipselink.entity.Employee;

public class ManyToOne 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager( );
		entitymanager.getTransaction( ).begin( );
		
		//Create Department Entity
		Department department = new Department();
		department.setName("Development");
		//Store Department
		entitymanager.persist(department);
		
		//Create Employee1 Entity
		Employee employee1 = new Employee();
		employee1.setEname("Satish");
		employee1.setSalary(45000.0);
		employee1.setDeg("Technical Writer");
		employee1.setDepartment(department);

		//Create Employee2 Entity
		Employee employee2 = new Employee();
		employee2.setEname("Krishna");
		employee2.setSalary(45000.0);
		employee2.setDeg("Technical Writer");
		employee2.setDepartment(department);

		//Create Employee3 Entity
		Employee employee3 = new Employee();
		employee3.setEname("Masthanvali");
		employee3.setSalary(50000.0);
		employee3.setDeg("Technical Writer");
		employee3.setDepartment(department);
		
		//Store Employees
		entitymanager.persist(employee1);
		entitymanager.persist(employee2);
		entitymanager.persist(employee3);
				
		entitymanager.getTransaction().commit();
		entitymanager.close();
		emfactory.close();
	}
}

उपरोक्त कार्यक्रम को संकलित और निष्पादित करने के बाद, आपको ग्रहण आईडीई के कंसोल पैनल पर सूचनाएं मिलेंगी। आउटपुट के लिए, MySQL कार्यक्षेत्र की जाँच करें। इस उदाहरण में, दो तालिकाएँ बनाई गई हैं।

MySQL इंटरफ़ेस में निम्नलिखित क्वेरी और परिणाम Department तालिका निम्नानुसार प्रदर्शित की जाएगी:

Select * from department
ईद नाम
101 विकास

MySQL इंटरफ़ेस में निम्नलिखित क्वेरी और परिणाम Employee तालिका निम्नानुसार प्रदर्शित की जाएगी।

Select * from employee
ईद डिग्री Ename वेतन Department_Id
102 तकनीकी लेखक सतीश 45,000 101
103 तकनीकी लेखक कृष्णा 45,000 101
104 तकनीकी लेखक Masthanwali 50000 101

उपरोक्त तालिका में डिपारमेंट_ आई विभाग तालिका से विदेशी कुंजी (संदर्भ क्षेत्र) है।

@OneToMany संबंध

इस संबंध में, एक इकाई की प्रत्येक पंक्ति को अन्य इकाई में कई चाइल्ड रिकॉर्ड के लिए संदर्भित किया जाता है। महत्वपूर्ण बात यह है कि बच्चे के रिकॉर्ड में कई माता-पिता नहीं हो सकते हैं। टेबल ए और टेबल बी के बीच एक-से-कई संबंधों में, टेबल ए में प्रत्येक पंक्ति को टेबल बी में एक या कई पंक्तियों से जोड़ा जा सकता है।

आइए उपरोक्त उदाहरण पर विचार करें। मान लीजिए कि ऊपर दिए गए उदाहरण में कर्मचारी और विभाग की तालिकाएँ एक दूसरे से जुड़े हुए हैं, तो यह संबंध एक-से-कई संबंध बन जाता है। नामांकित ग्रहण आईडीई में एक जेपीए परियोजना बनाएंJPA_Eclipselink_OTM। इस परियोजना के सभी मॉड्यूल नीचे चर्चा कर रहे हैं।

संस्थाओं का निर्माण

संस्थाएँ बनाने के लिए ऊपर दिए गए आरेख का पालन करें। नाम का पैकेज बनाएं‘com.tutorialspoin.eclipselink.entity’ के अंतर्गत ‘src’पैकेज। नाम से एक क्लास बनाएंDepartment.javaदिए गए पैकेज के तहत। वर्ग विभाग इकाई को निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import java.util.List;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToMany;

@Entity
public class Department 
{
    @Id 
    @GeneratedValue( strategy=GenerationType.AUTO )
    private int id;
    private String name;
    
    @OneToMany( targetEntity=Employee.class )
    private List employeelist;

    public int getId() 
    {
    	return id;
    }
    
    public void setId(int id) 
    {
    	this.id = id;
    }
    
    public String getName( )
    {
    	return name;
    }
    
    public void setName( String deptName )
    {
    	this.name = deptName;
    }

    public List getEmployeelist() 
    {
	return employeelist;
    }

    public void setEmployeelist(List employeelist) 
    {
	this.employeelist = employeelist;
    }
}

इस संबंध में दूसरी इकाई बनाएँ-कर्मचारी इकाई, नाम Employee.java के अंतर्गत ‘com.tutorialspoint.eclipselink.entity’पैकेज। कर्मचारी इकाई वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class Employee 
{
	@Id
	@GeneratedValue( strategy= GenerationType.AUTO ) 	
	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;
	}	
}

Persistence.xml

दृढ़ता। Xml फ़ाइल निम्नानुसार है:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" 
             xmlns="http://java.sun.com/xml/ns/persistence" 
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
             xsi:schemaLocation="http://java.sun.com/xml/ns/persistence 
             http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
	<persistence-unit name="Eclipselink_JPA" 
                        transaction-type="RESOURCE_LOCAL">
	<class>com.tutorialspoint.eclipselink.entity.Employee</class>
	<class>com.tutorialspoint.eclipselink.entity.Department</class>
		<properties>
			<property name="javax.persistence.jdbc.url" 
			          value="jdbc:mysql://localhost:3306/jpadb"/>
			<property name="javax.persistence.jdbc.user" value="root"/>
			<property name="javax.persistence.jdbc.password" 
                            value="root"/>
			<property name="javax.persistence.jdbc.driver" 
			          value="com.mysql.jdbc.Driver"/>
			<property name="eclipselink.logging.level" value="FINE"/>
			<property name="eclipselink.ddl-generation" 
			          value="create-tables"/>
		</properties>
	</persistence-unit>
</persistence>

सेवा वर्ग

इस मॉड्यूल में सेवा वर्ग शामिल हैं, जो विशेषता आरंभीकरण का उपयोग करके रिलेशनल भाग को लागू करता है। के तहत एक पैकेज बनाएं‘src’ पैकेज का नाम ‘com.tutorialspoint.eclipselink.service’। नाम दिया गया DAO वर्गOneToMany.javaदिए गए पैकेज के तहत बनाया गया है। DAO वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspointeclipselink.service;

import java.util.List;
import java.util.ArrayList;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.Department;
import com.tutorialspoint.eclipselink.entity.Employee;

public class OneToMany 
{
	public static void main(String[] args) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager( );
		entitymanager.getTransaction( ).begin( );
		
		//Create Employee1 Entity
		Employee employee1 = new Employee();
		employee1.setEname("Satish");
		employee1.setSalary(45000.0);
		employee1.setDeg("Technical Writer");
								
		//Create Employee2 Entity
		Employee employee2 = new Employee();
		employee2.setEname("Krishna");
		employee2.setSalary(45000.0);
		employee2.setDeg("Technical Writer");
								
		//Create Employee3 Entity
		Employee employee3 = new Employee();
		employee3.setEname("Masthanvali");
		employee3.setSalary(50000.0);
		employee3.setDeg("Technical Writer");
		
		//Store Employee
		entitymanager.persist(employee1);
		entitymanager.persist(employee2);
		entitymanager.persist(employee3);
		
		//Create Employeelist
		List<Employee> emplist = new ArrayList();
		emplist.add(employee1);
		emplist.add(employee2);
		emplist.add(employee3);
		
		//Create Department Entity
		Department department= new Department();
		department.setName("Development");
		department.setEmployeelist(emplist);
				
		//Store Department
		entitymanager.persist(department);
		
		entitymanager.getTransaction().commit();
		entitymanager.close();
		emfactory.close();
	}
}

उपरोक्त कार्यक्रम के संकलन और निष्पादन के बाद आपको ग्रहण आईडीई के कंसोल पैनल में सूचनाएं मिलेंगी। आउटपुट की जाँच के लिए MySQL कार्यक्षेत्र निम्नानुसार है।

इस परियोजना में तीन तालिकाओं का निर्माण किया जाता है। MySQL इंटरफ़ेस में निम्नलिखित क्वेरी पास करें और Department_employee तालिका का परिणाम निम्नानुसार प्रदर्शित किया जाएगा:

Select * from department_Id;
Department_ID Employee_Eid
254 251
254 252
254 253

उपरोक्त तालिका में, deparment_id तथा employee_id विभाग और कर्मचारी तालिकाओं से विदेशी कुंजी (संदर्भ फ़ील्ड) हैं।

MySQL इंटरफ़ेस में निम्नलिखित क्वेरी पास करें और विभाग तालिका का परिणाम निम्नानुसार एक सारणीबद्ध प्रारूप में प्रदर्शित किया जाएगा।

Select * from department;
ईद नाम
254 विकास

MySQL इंटरफ़ेस में निम्न क्वेरी पास करें और कर्मचारी तालिका का परिणाम निम्नानुसार प्रदर्शित किया जाएगा:

Select * from employee;
ईद डिग्री Ename वेतन
251 तकनीकी लेखक सतीश 45,000
252 तकनीकी लेखक कृष्णा 45,000
253 तकनीकी लेखक Masthanwali 50000

@OneToOne संबंध

वन-टू-वन रिलेशनशिप में, एक आइटम को केवल एक अन्य आइटम से जोड़ा जा सकता है। इसका मतलब है कि एक इकाई की प्रत्येक पंक्ति को एक और किसी अन्य इकाई की केवल एक पंक्ति को संदर्भित किया जाता है।

आइए उपरोक्त उदाहरण पर विचार करें। Employee तथा Departmentरिवर्स यूनिडायरेक्शनल तरीके से, रिश्ता वन-टू-वन रिलेशन है। इसका अर्थ है कि प्रत्येक कर्मचारी केवल एक विभाग का है। नामांकित ग्रहण आईडीई में एक जेपीए परियोजना बनाएंJPA_Eclipselink_OTO। इस परियोजना के सभी मॉड्यूल नीचे चर्चा कर रहे हैं।

संस्थाओं का निर्माण

संस्थाएँ बनाने के लिए ऊपर दिए गए आरेख का पालन करें। नाम का पैकेज बनाएं‘com.tutorialspoin.eclipselink.entity’ के अंतर्गत ‘src’पैकेज। नाम से एक क्लास बनाएंDepartment.javaदिए गए पैकेज के तहत। वर्ग विभाग इकाई को निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class Department 
{
    @Id 
    @GeneratedValue( strategy=GenerationType.AUTO )
    private int id;
    private String name;
   
    public int getId() 
    {
    	return id;
    }
    
    public void setId(int id) 
    {
    	this.id = id;
    }
    
    public String getName( )
    {
    	return name;
    }
    
    public void setName( String deptName )
    {
    	this.name = deptName;
    }
}

इस संबंध में दूसरी इकाई बनाएँ-कर्मचारी इकाई, नाम Employee.java के अंतर्गत ‘com.tutorialspoint.eclipselink.entity’पैकेज। कर्मचारी इकाई वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToOne;

@Entity
public class Employee 
{
	@Id
	@GeneratedValue( strategy= GenerationType.AUTO ) 	
	private int eid;
	private String ename;
	private double salary;
	private String deg;
	
	@OneToOne
	private Department department;
		
	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;
	}

	public Department getDepartment() 
	{
		return department;
	}

	public void setDepartment(Department department) 
	{
		this.department = department;
	}	
}

Persistence.xml

Persistence.xml फ़ाइल निम्नानुसार है:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" 
             xmlns="http://java.sun.com/xml/ns/persistence" 
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
             xsi:schemaLocation="http://java.sun.com/xml/ns/persistence 
             http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
	<persistence-unit name="Eclipselink_JPA" 
                        transaction-type="RESOURCE_LOCAL">
	<class>com.tutorialspoint.eclipselink.entity.Employee</class>
	<class>com.tutorialspoint.eclipselink.entity.Department</class>
		<properties>
			<property name="javax.persistence.jdbc.url" 
			          value="jdbc:mysql://localhost:3306/jpadb"/>
			<property name="javax.persistence.jdbc.user" value="root"/>
			<property name="javax.persistence.jdbc.password" 
                            value="root"/>
			<property name="javax.persistence.jdbc.driver" 
			          value="com.mysql.jdbc.Driver"/>
			<property name="eclipselink.logging.level" value="FINE"/>
			<property name="eclipselink.ddl-generation" 
			          value="create-tables"/>
		</properties>
	</persistence-unit>
</persistence>

सेवा वर्ग

के तहत एक पैकेज बनाएं ‘src’ पैकेज का नाम ‘com.tutorialspoint.eclipselink.service’। नाम दिया गया DAO वर्गOneToOne.javaदिए गए पैकेज के तहत बनाया गया है। DAO वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspointeclipselink.service;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.Department;
import com.tutorialspoint.eclipselink.entity.Employee;

public class OneToOne 
{
	public static void main(String[] args) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager( );
		entitymanager.getTransaction( ).begin( );
		
		//Create Department Entity
		Department department = new Department();
		department.setName("Development");
		
		//Store Department
		entitymanager.persist(department);
		
		//Create Employee Entity
		Employee employee = new Employee();
		employee.setEname("Satish");
		employee.setSalary(45000.0);
		employee.setDeg("Technical Writer");
		employee.setDepartment(department);
		
		//Store Employee
		entitymanager.persist(employee);
		
		entitymanager.getTransaction().commit();
		entitymanager.close();
		emfactory.close();
	}
}

उपरोक्त कार्यक्रम के संकलन और निष्पादन के बाद आपको ग्रहण आईडीई के कंसोल पैनल में सूचनाएं मिलेंगी। आउटपुट के लिए, निम्नानुसार MySQL कार्यक्षेत्र की जाँच करें।

उपरोक्त उदाहरण में, दो तालिकाओं का निर्माण किया जाता है। MySQL इंटरफ़ेस में निम्नलिखित क्वेरी पास करें और विभाग तालिका का परिणाम निम्नानुसार प्रदर्शित किया जाएगा:

Select * from department
ईद नाम
301 विकास

MySQL इंटरफ़ेस में निम्नलिखित क्वेरी और परिणाम employee तालिका निम्नानुसार प्रदर्शित की जाएगी:

Select * from employee
ईद डिग्री Ename वेतन Department_id
302 तकनीकी लेखक सतीश 45,000 301

@ManyToMany संबंध

कई-से-कई संबंध वह है जहां एक इकाई से एक या एक से अधिक पंक्तियां अन्य इकाई में एक से अधिक पंक्ति से जुड़ी होती हैं।

आइए हम दो संस्थाओं के बीच संबंध के एक उदाहरण पर विचार करें: Class तथा Teacher। द्विदिश तरीके से, कक्षा और शिक्षक दोनों के कई-से-एक संबंध हैं। इसका मतलब है कि कक्षा का प्रत्येक रिकॉर्ड शिक्षक सेट (शिक्षक आईडी) द्वारा संदर्भित किया जाता है, जिसे शिक्षक तालिका में प्राथमिक कुंजी होना चाहिए और शिक्षक_क्लास तालिका और इसके विपरीत में संग्रहीत किया जाना चाहिए। यहां, Teachers_Class तालिका में दोनों विदेशी कुंजी फ़ील्ड शामिल हैं। नामांकित ग्रहण आईडीई में एक जेपीए परियोजना बनाएंJPA_Eclipselink_MTM। इस परियोजना के सभी मॉड्यूल नीचे चर्चा कर रहे हैं।

संस्थाओं का निर्माण

ऊपर दिए गए आरेख में दिखाए गए स्कीमा का पालन करके इकाइयां बनाएं। नाम का पैकेज बनाएं‘com.tutorialspoin.eclipselink.entity’ के अंतर्गत ‘src’पैकेज। नाम से एक क्लास बनाएंClas.javaदिए गए पैकेज के तहत। वर्ग विभाग इकाई को निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import java.util.Set;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.ManyToMany;

@Entity
public class Clas 
{
	@Id
	@GeneratedValue( strategy = GenerationType.AUTO )
	private int cid;
	private String cname;
	
	@ManyToMany(targetEntity=Teacher.class)
	private Set teacherSet;
	
	public Clas() 
	{
		super();
	}
	public Clas(int cid, 
			String cname, Set teacherSet) 
	{
		super();
		this.cid = cid;
		this.cname = cname;
		this.teacherSet = teacherSet;
	}
	public int getCid() 
	{
		return cid;
	}
	public void setCid(int cid) 
	{
		this.cid = cid;
	}
	public String getCname() 
	{
		return cname;
	}
	public void setCname(String cname) 
	{
		this.cname = cname;
	}
	public Set getTeacherSet() 
	{
		return teacherSet;
	}
	public void setTeacherSet(Set teacherSet) 
	{
		this.teacherSet = teacherSet;
	}	  
}

इस संबंध में दूसरी इकाई बनाएँ-कर्मचारी इकाई, नाम Teacher.java के अंतर्गत ‘com.tutorialspoint.eclipselink.entity’पैकेज। कर्मचारी इकाई वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import java.util.Set;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.ManyToMany;

@Entity
public class Teacher 
{
	@Id
	@GeneratedValue( strategy = GenerationType.AUTO )
	private int tid;
	private String tname;
	private String subject;
	
	@ManyToMany(targetEntity=Clas.class)
	private Set clasSet;
	
	public Teacher() 
	{
		super();
	}
	public Teacher(int tid, String tname, String subject, 
			Set clasSet) 
	{
		super();
		this.tid = tid;
		this.tname = tname;
		this.subject = subject;
		this.clasSet = clasSet;
	}
	public int getTid() 
	{
		return tid;
	}
	public void setTid(int tid) 
	{
		this.tid = tid;
	}
	public String getTname() 
	{
		return tname;
	}
	public void setTname(String tname) 
	{
		this.tname = tname;
	}
	public String getSubject() 
	{
		return subject;
	}
	public void setSubject(String subject) 
	{
		this.subject = subject;
	}
	public Set getClasSet() 
	{
		return clasSet;
	}
	public void setClasSet(Set clasSet) 
	{
		this.clasSet = clasSet;
	}
}

Persistence.xml

Persistence.xml फ़ाइल निम्नानुसार है:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" 
             xmlns="http://java.sun.com/xml/ns/persistence" 
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
             xsi:schemaLocation="http://java.sun.com/xml/ns/persistence 
             http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
	<persistence-unit name="Eclipselink_JPA" 
                        transaction-type="RESOURCE_LOCAL">
	<class>com.tutorialspoint.eclipselink.entity.Employee</class>
	<class>com.tutorialspoint.eclipselink.entity.Department</class>
		<properties>
			<property name="javax.persistence.jdbc.url" 
			          value="jdbc:mysql://localhost:3306/jpadb"/>
			<property name="javax.persistence.jdbc.user" value="root"/>
			<property name="javax.persistence.jdbc.password" 
                            value="root"/>
			<property name="javax.persistence.jdbc.driver" 
			          value="com.mysql.jdbc.Driver"/>
			<property name="eclipselink.logging.level" value="FINE"/>
			<property name="eclipselink.ddl-generation" 
			          value="create-tables"/>
		</properties>
	</persistence-unit>
</persistence>

सेवा वर्ग

के तहत एक पैकेज बनाएं ‘src’ पैकेज का नाम ‘com.tutorialspoint.eclipselink.service’। नाम दिया गया DAO वर्गManyToMany.javaदिए गए पैकेज के तहत बनाया गया है। DAO वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.service;

import java.util.HashSet;
import java.util.Set;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.Clas;
import com.tutorialspoint.eclipselink.entity.Teacher;

public class ManyToMany 
{
	public static void main(String[] args) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager( );
		entitymanager.getTransaction( ).begin( );
		
		//Create Clas Entity
		Clas clas1=new Clas(0,"1st",null);
		Clas clas2=new Clas(0,"2nd",null);
		Clas clas3=new Clas(0,"3rd",null);
		
		//Store Clas
		entitymanager.persist(clas1);
		entitymanager.persist(clas2);
		entitymanager.persist(clas3);
		
		//Create Clas Set1
		Set<Clas> classSet1 = new HashSet();
		classSet1.add(clas1);
		classSet1.add(clas2);
		classSet1.add(clas3);
		
		//Create Clas Set2
		Set<Clas> classSet2 = new HashSet();
		classSet2.add(clas3);
		classSet2.add(clas1);
		classSet2.add(clas2);
				
		//Create Clas Set3
		Set<Clas> classSet3 = new HashSet();
		classSet3.add(clas2);
		classSet3.add(clas3);
		classSet3.add(clas1);
		
		//Create Teacher Entity
		Teacher teacher1 = new Teacher(0,
				"Satish","Java",classSet1);
		Teacher teacher2 = new Teacher(0,
				"Krishna","Adv Java",classSet2);
		Teacher teacher3 = new Teacher(0,
				"Masthanvali","DB2",classSet3);
		
		//Store Teacher
		entitymanager.persist(teacher1);
		entitymanager.persist(teacher2);
		entitymanager.persist(teacher3);
		
		entitymanager.getTransaction( ).commit( );
		entitymanager.close( );
		emfactory.close( );
	}
}

इस उदाहरण प्रोजेक्ट में, तीन तालिकाएँ बनाई जाती हैं। MySQL इंटरफ़ेस में निम्नलिखित क्वेरी पास करें और शिक्षक_क्लास तालिका का परिणाम निम्नानुसार प्रदर्शित किया जाएगा:

Select * form teacher_clas
Teacher_tid Classet_cid
354 351
355 351
356 351
354 352
355 352
356 352
354 353
355 353
356 353

उपरोक्त तालिका में teacher_tid शिक्षक तालिका से विदेशी कुंजी है, और classet_cidकक्षा की मेज से विदेशी कुंजी है। इसलिए विभिन्न शिक्षकों को अलग-अलग कक्षा के लिए आवंटित किया जाता है।

MySQL इंटरफ़ेस में निम्न क्वेरी पास करें और शिक्षक तालिका का परिणाम निम्नानुसार प्रदर्शित किया जाएगा:

Select * from teacher
टीआईडी विषय Tname
354 जावा सतीश
355 जावा को सलाह दें कृष्णा
356 डीबी 2 Masthanvali

MySQL इंटरफ़ेस में निम्नलिखित क्वेरी और परिणाम clas तालिका निम्नानुसार प्रदर्शित की जाएगी:

Select * from clas
सीआइडी Cname
351 1
352 2
353 3

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

मानदंड एपीआई का मुख्य लाभ यह है कि संकलन समय के दौरान त्रुटियों का पहले ही पता लगाया जा सकता है। स्ट्रिंग-आधारित JPQL क्वेरीज़ और JPA मानदंड आधारित क्वेरीज़ प्रदर्शन और दक्षता में समान हैं।

मापदंड एपीआई का इतिहास

मानदंड को जेपीए के सभी संस्करणों में शामिल किया गया है, इसलिए मानदंड के प्रत्येक चरण को जेपीए के विनिर्देशों में अधिसूचित किया गया है।

  • JPA 2.0 में, मापदंड क्वेरी API, प्रश्नों का मानकीकरण विकसित किया गया है।
  • जेपीए 2.1 में, मानदंड अद्यतन और हटाना (बल्क अपडेट और डिलीट) शामिल हैं।

मानदंड क्वेरी संरचना

मानदंड और JPQL बारीकी से संबंधित हैं और उनके प्रश्नों में समान ऑपरेटरों का उपयोग करके डिजाइन करने की अनुमति है। का अनुसरण करनाjavax.persistence.criteriaपैकेज एक क्वेरी डिजाइन करने के लिए। क्वेरी संरचना का अर्थ सिंटैक्स मानदंड क्वेरी है।

निम्न साधारण मापदंड क्वेरी डेटा स्रोत में इकाई वर्ग के सभी उदाहरणों को लौटाता है।

EntityManager em = ...;
CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Entity class> cq = cb.createQuery(Entity.class);
Root<Entity> from = cq.from(Entity.class);
cq.select(Entity);
TypedQuery<Entity> q = em.createQuery(cq);
List<Entity> allitems = q.getResultList();

मानदंड बनाने के लिए क्वेरी मूल चरणों का प्रदर्शन करती है।

  • EntityManager उदाहरण का उपयोग मानदंड वस्तु बनाने के लिए किया जाता है।

  • CriteriaQueryउदाहरण का उपयोग क्वेरी ऑब्जेक्ट बनाने के लिए किया जाता है। इस क्वेरी ऑब्जेक्ट की विशेषताओं को क्वेरी के विवरण के साथ संशोधित किया जाएगा।

  • CriteriaQuery.form क्वेरी रूट सेट करने के लिए विधि को कहा जाता है।

  • CriteriaQuery.select परिणाम सूची प्रकार सेट करने के लिए कहा जाता है।

  • TypedQuery<T> उदाहरण का उपयोग निष्पादन परिणाम के प्रकार को निर्दिष्ट करने और निर्दिष्ट करने के लिए एक क्वेरी तैयार करने के लिए किया जाता है।

  • getResultListकिसी क्वेरी को निष्पादित करने के लिए टाइप करेंडाइक <T> ऑब्जेक्ट पर विधि। यह क्वेरी संस्थाओं का एक संग्रह लौटाती है, परिणाम एक सूची में संग्रहीत होता है।

मापदंड एपीआई का उदाहरण

आइए हम कर्मचारी डेटाबेस के उदाहरण पर विचार करें। हमें मान लें कि jpadb.employee तालिका में निम्नलिखित रिकॉर्ड हैं:

Eid	 Ename          Salary	Deg
401	 Gopal	        40000	Technical Manager
402	 Manisha	    40000	Proof reader
403	 Masthanvali    35000	Technical Writer
404  Satish	        30000	Technical writer
405	 Krishna	    30000	Technical Writer
406	 Kiran	        35000	Proof reader

नामांकित ग्रहण IDE में एक JPA प्रोजेक्ट बनाएं JPA_Eclipselink_Criteria। इस परियोजना के सभी मॉड्यूल नीचे चर्चा कर रहे हैं:

संस्थाओं का निर्माण

नाम का पैकेज बनाएं com.tutorialspoint.eclipselink.entity के अंतर्गत ‘src’

नाम से एक क्लास बनाएं Employee.javaदिए गए पैकेज के तहत। कर्मचारी वर्ग को निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class Employee 
{
	@Id
	@GeneratedValue(strategy= GenerationType.AUTO) 	
	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;
	}
	@Override
	public String toString() {
		return "Employee [eid=" + eid + ", ename=" + ename + ", salary="
				+ salary + ", deg=" + deg + "]";
	}
}

Persistence.xml

Persistence.xml फ़ाइल निम्नानुसार है:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" 
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
             xsi:schemaLocation="http://java.sun.com/xml/ns/persistence 
             http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
	<persistence-unit name="Eclipselink_JPA" 
                        transaction-type="RESOURCE_LOCAL">
	<class>com.tutorialspoint.eclipselink.entity.Employee</class>
		<properties>
			<property name="javax.persistence.jdbc.url" 
			          value="jdbc:mysql://localhost:3306/jpadb"/>
			<property name="javax.persistence.jdbc.user" value="root"/>
			<property name="javax.persistence.jdbc.password" 
			          value="root"/>
			<property name="javax.persistence.jdbc.driver" 
			          value="com.mysql.jdbc.Driver"/>
			<property name="eclipselink.logging.level" value="FINE"/>
			<property name="eclipselink.ddl-generation" 
			          value="create-tables"/>
		</properties>
	</persistence-unit>
</persistence>

सेवा वर्ग

इस मॉड्यूल में सेवा वर्ग शामिल हैं, जो मेटाडेटा एपीआई आरंभीकरण का उपयोग करके मानदंड क्वेरी भाग को लागू करता है। नाम का पैकेज बनाएं‘com.tutorialspoint.eclipselink.service’। नाम का वर्गCriteriaAPI.javaदिए गए पैकेज के तहत बनाया गया है। DAO वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.service;

import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.TypedQuery;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;
import com.tutorialspoint.eclipselink.entity.Employee;

public class CriteriaApi 
{
	public static void main(String[] args) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager( );
		CriteriaBuilder criteriaBuilder = entitymanager
				.getCriteriaBuilder();
		CriteriaQuery<Object> criteriaQuery = criteriaBuilder
				.createQuery();
		Root<Employee> from = criteriaQuery.from(Employee.class);
		
		//select all records
        System.out.println(“Select all records”);
		CriteriaQuery<Object> select =criteriaQuery.select(from);
		TypedQuery<Object> typedQuery = entitymanager
				.createQuery(select);
		List<Object> resultlist= typedQuery.getResultList();
		
		for(Object o:resultlist)
		{
			Employee e=(Employee)o;
			System.out.println("EID : "+e.getEid()
					+" Ename : "+e.getEname());
		}
		
		//Ordering the records 
        System.out.println(“Select all records by follow ordering”);
		CriteriaQuery<Object> select1 = criteriaQuery.select(from);
        select1.orderBy(criteriaBuilder.asc(from.get("ename")));
        TypedQuery<Object> typedQuery1 = entitymanager
        		.createQuery(select);
        List<Object> resultlist1= typedQuery1.getResultList();
		
		for(Object o:resultlist1)
		{
			Employee e=(Employee)o;
			System.out.println("EID : "+e.getEid()
					+" Ename : "+e.getEname());
		}
		
		entitymanager.close( );
		emfactory.close( );
	}
}

उपरोक्त कार्यक्रम को संकलित और निष्पादित करने के बाद आपको ग्रहण आईडीई के कंसोल पैनल में निम्नलिखित आउटपुट मिलेगा।

Select All records
EID : 401 Ename : Gopal
EID : 402 Ename : Manisha
EID : 403 Ename : Masthanvali
EID : 404 Ename : Satish
EID : 405 Ename : Krishna
EID : 406 Ename : Kiran
Select All records by follow Ordering
EID : 401 Ename : Gopal
EID : 406 Ename : Kiran
EID : 405 Ename : Krishna
EID : 402 Ename : Manisha
EID : 403 Ename : Masthanvali
EID : 404 Ename : Satish