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