जेपीए - इकाई संबंध
यह अध्याय आपको संस्थाओं के बीच संबंधों के माध्यम से ले जाता है। आमतौर पर डेटाबेस में तालिकाओं के बीच संबंध अधिक प्रभावी होते हैं। यहां इकाई वर्गों को संबंधपरक तालिकाओं (JPA की अवधारणा) के रूप में माना जाता है, इसलिए इकाई वर्गों के बीच संबंध निम्नानुसार हैं:
- @ManyToOne संबंध
- @OneToMany संबंध
- @OneToOne संबंध
- @ManyToMany संबंध
@ManyToOne संबंध
संस्थाओं के बीच कई-से-एक संबंध: जहां एक इकाई (स्तंभों का स्तंभ या सेट) दूसरी इकाई (स्तंभों या स्तंभों के समूह) से संदर्भित होती है, जिसमें अद्वितीय मूल्य होते हैं। संबंधपरक डेटाबेस में ये संबंध तालिकाओं के बीच विदेशी कुंजी / प्राथमिक कुंजी का उपयोग करके लागू होते हैं।
आइए हम कर्मचारी और विभाग संस्थाओं के बीच संबंध के एक उदाहरण पर विचार करें। यूनिडायरेक्शनल तरीके से, iefrom कर्मचारी से विभाग तक, कई-से-एक संबंध लागू होता है। इसका मतलब है कि कर्मचारी के प्रत्येक रिकॉर्ड में एक विभाग आईडी होता है, जो विभाग की तालिका में एक प्राथमिक कुंजी होना चाहिए। यहां कर्मचारी तालिका में, विभाग आईडी विदेशी कुंजी है।
आरेख निम्नानुसार कई-से-एक संबंध बताता है:
नामांकित ग्रहण आईडीई में एक जेपीए परियोजना बनाएं 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;
Id Name
101 Development
MySQL इंटरफ़ेस में निम्नलिखित क्वेरी और परिणाम Employee सारणी में तालिका तालिका प्रारूप में निम्नानुसार दिखाई गई है:
Select * from employee;
Eid Deg Ename Salary Department_Id
102 Technical Writer Satish 45000 101
103 Technical Writer Krishna 45000 101
104 Technical Writer Masthan Wali 50000 101
उपरोक्त तालिका में डिपारमेंट_ आई विभाग तालिका से विदेशी कुंजी (संदर्भ क्षेत्र) है।
@OneToMany संबंध
इस संबंध में एक इकाई की प्रत्येक पंक्ति को अन्य इकाई में कई चाइल्ड रिकॉर्ड के लिए संदर्भित किया जाता है। महत्वपूर्ण बात यह है कि बच्चे के रिकॉर्ड में कई माता-पिता नहीं हो सकते हैं। टेबल ए और टेबल बी के बीच एक-से-कई संबंधों में, टेबल ए में प्रत्येक पंक्ति को टेबल बी में 0, 1 या कई पंक्तियों से जोड़ा जाता है।
आइए उपरोक्त उदाहरण पर विचार करें। अगरEmployee तथा Departmentएक रिवर्स यूनिडायरेक्शनल तरीके से है, रिलेशन कई-टू-वन रिलेशन है। नामांकित ग्रहण आईडीई में एक जेपीए परियोजना बनाएं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
PPA प्रोजेक्ट बनाते समय ग्रहण IDE द्वारा 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 और कर्मचारी_id फ़ील्ड विदेशी कुंजी (संदर्भ फ़ील्ड) हैं।
MySQL इंटरफ़ेस में निम्न क्वेरी पास करें और सारणी में विभाग तालिका का परिणाम निम्नानुसार दिखाया गया है:
Select * from department;
Id Name
254 Development
MySQL इंटरफ़ेस में निम्न क्वेरी पास करें और तालिका में निम्न रूप में एक तालिका प्रारूप में कर्मचारी तालिका का परिणाम दिखाया गया है:
Select * from employee;
Eid Deg Ename Salary
251 Technical Writer Satish 45000
252 Technical Writer Krishna 45000
253 Technical Writer Masthanvali 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
PPA प्रोजेक्ट बनाते समय ग्रहण IDE द्वारा 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 वर्ग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 इंटरफ़ेस में निम्नलिखित क्वेरी और परिणाम department सारणी में तालिका तालिका प्रारूप में निम्नानुसार दिखाई गई है:
Select * from department
Id Name
301 Development
MySQL इंटरफ़ेस में निम्नलिखित क्वेरी और परिणाम employee सारणी में तालिका तालिका प्रारूप में निम्नानुसार दिखाई गई है:
Select * from employee
Eid Deg Ename Salary Department_id
302 Technical Writer Satish 45000 301
@ManyToMany संबंध
कई-से-कई संबंध वह है जहां एक इकाई से एक या एक से अधिक पंक्तियां अन्य इकाई में एक से अधिक पंक्ति से जुड़ी होती हैं।
आइए कक्षा और शिक्षक संस्थाओं के बीच संबंध के एक उदाहरण पर विचार करें। द्विदिश तरीके से, कक्षा और शिक्षक दोनों के कई-से-एक संबंध हैं। इसका मतलब है कि कक्षा का प्रत्येक रिकॉर्ड शिक्षक सेट (शिक्षक आईडी) द्वारा संदर्भित किया जाता है, जिसे शिक्षक तालिका में प्राथमिक कुंजी और शिक्षक_क्लास तालिका में संग्रहीत किया जाना चाहिए और इसके विपरीत। यहां, 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 एक EPA प्रोजेक्ट के दौरान ग्रहण आईडीई द्वारा बनाया जाएगा। कॉन्फ़िगरेशन विवरण उपयोगकर्ता के विनिर्देश हैं। दृढ़ता। 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 कार्यक्षेत्र की जाँच करें। इस उदाहरण प्रोजेक्ट में, तीन तालिकाएँ बनाई जाती हैं।
MySQL इंटरफ़ेस में निम्नलिखित क्वेरी और परिणाम teacher_clas सारणी में तालिका तालिका प्रारूप में निम्नानुसार दिखाई गई है।
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
उपर्युक्त तालिका में शिक्षक_शिक्षक शिक्षक तालिका से विदेशी कुंजी है, और कक्षा तालिका से classet_cid विदेशी कुंजी है। इसलिए विभिन्न शिक्षकों को अलग-अलग कक्षा के लिए आवंटित किया जाता है।
MySQL इंटरफ़ेस में निम्न क्वेरी पास करें और तालिका में निम्नानुसार एक तालिका प्रारूप में शिक्षक तालिका का परिणाम दिखाया गया है:
Select * from teacher;
Tid Subject Tname
354 Java Satish
355 Adv Java Krishna
356 DB2 Masthanvali
MySQL इंटरफ़ेस में निम्नलिखित क्वेरी और परिणाम clas सारणी में तालिका तालिका प्रारूप में निम्नानुसार दिखाई गई है:
Select * from clas;
cid Cname
351 1st
352 2nd
353 3rd