जेपीए - इकाई प्रबंधक

यह अध्याय आपको जेपीए के साथ सरल उदाहरण के माध्यम से ले जाता है। आइए हम कर्मचारी प्रबंधन को उदाहरण के रूप में मानते हैं। इसका मतलब है कि कर्मचारी प्रबंधन किसी कर्मचारी को बना रहा है, अपडेट कर रहा है, ढूंढ रहा है और हटा रहा है। जैसा कि ऊपर बताया गया है कि हम डेटाबेस संचालन के लिए 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 कार्यक्षेत्र खोलें और क्वेरी निम्न प्रकार है:

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>

उपरोक्त एक्सएमएल में, <दृढ़ता-इकाई> टैग को जेपीए दृढ़ता के लिए विशिष्ट नाम से परिभाषित किया गया है। <Class> टैग पैकेज के नाम के साथ इकाई वर्ग को परिभाषित करता है। <गुण> टैग सभी गुणों को परिभाषित करता है, और <गुण> टैग डेटाबेस पंजीकरण, 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 फ़ाइल। Unitmanagerfactory वस्तु का उपयोग करके Unitmanger उदाहरण बनाएगाcreateEntityManager ()तरीका। एंटेरमैनेजर ऑब्जेक्ट लेन-देन प्रबंधन के लिए एन्ट्राप्रान्सरेशन उदाहरण बनाता है। Unitmanager ऑब्जेक्ट का उपयोग करके, हम संस्थाओं को डेटाबेस में बनाए रख सकते हैं।

उपरोक्त कार्यक्रम के संकलन और निष्पादन के बाद आपको ग्रहण आईडीई के कंसोल पैनल पर 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 अशक्त रिकॉर्ड होंगे।

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