JPA - Hubungan Entitas
Bab ini membawa Anda melalui hubungan antara Entitas. Umumnya relasi lebih efektif antar tabel dalam database. Di sini kelas entitas diperlakukan sebagai tabel relasional (konsep JPA), oleh karena itu hubungan antar kelas Entitas adalah sebagai berikut:
- Hubungan @anyToOne
- @OneTany Relation
- @OneToOne Relation
- @ManyTany Relation
Hubungan @anyToOne
Relasi Many-To-One antar entitas: Di mana satu entitas (kolom atau kumpulan kolom) direferensikan dengan entitas lain (kolom atau kumpulan kolom) yang berisi nilai unik. Dalam database relasional, hubungan ini dapat diterapkan dengan menggunakan kunci asing / kunci primer antar tabel.
Mari kita pertimbangkan contoh hubungan antara entitas Karyawan dan Departemen. Dengan cara searah, hubungan dari Karyawan ke Departemen, hubungan Banyak-ke-Satu dapat diterapkan. Itu berarti setiap record karyawan berisi satu id departemen, yang seharusnya menjadi kunci utama dalam tabel Departemen. Di sini, di tabel Karyawan, id Departemen adalah kunci asing.
Diagram tersebut menjelaskan relasi Many-To-One sebagai berikut:
Buat proyek JPA dalam IDE eclipse bernama JPA_Eclipselink_MTO. Semua modul proyek ini ditampilkan sebagai berikut:
Membuat Entitas
Ikuti diagram yang diberikan di atas untuk membuat entitas. Buat paket bernama‘com.tutorialspoin.eclipselink.entity’ dibawah ‘src’paket. Buat kelas bernamaDepartment.javadi bawah paket yang diberikan. Entitas Departemen kelas ditampilkan sebagai berikut:
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;
}
}
Buat entitas kedua dalam relasi ini - Kelas entitas karyawan bernama Employee.java dibawah ‘com.tutorialspoint.eclipselink.entity’paket. Kelas entitas Karyawan ditampilkan sebagai berikut:
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
File Persistence.xml diperlukan untuk mengkonfigurasi database dan pendaftaran kelas entitas.
Persitence.xml akan dibuat oleh IDE gerhana saat membuat Proyek JPA. Detail konfigurasi adalah spesifikasi pengguna. File persistence.xml ditampilkan sebagai berikut:
<?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>
Kelas Layanan
Modul ini berisi kelas layanan, yang mengimplementasikan bagian relasional menggunakan inisialisasi atribut. Buat paket di bawah‘src’ paket bernama ‘com.tutorialspoint.eclipselink.service’. Kelas DAO bernamaManyToOne.javadibuat di bawah paket yang diberikan. Kelas DAO ditampilkan sebagai berikut:
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();
}
}
Setelah kompilasi dan eksekusi program di atas, Anda akan mendapatkan notifikasi di panel konsol Eclipse IDE. Untuk keluaran, periksa meja kerja MySQL. Dalam contoh ini dua tabel dibuat.
Teruskan kueri berikut di antarmuka MySQL dan hasil Department tabel dalam format tabel diperlihatkan sebagai berikut dalam kueri:
Select * from department;
Id Name
101 Development
Teruskan kueri berikut di antarmuka MySQL dan hasil Employee tabel dalam format tabel diperlihatkan sebagai berikut dalam kueri:
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
Dalam tabel di atas Deparment_Id adalah kunci asing (bidang referensi) dari tabel Departemen.
@OneTany Relation
Dalam hubungan ini, setiap baris dari satu entitas dirujuk ke banyak rekaman turunan di entitas lain. Yang penting adalah bahwa catatan anak tidak boleh memiliki banyak orang tua. Dalam hubungan satu ke banyak antara Tabel A dan Tabel B, setiap baris dalam Tabel A ditautkan ke 0, 1 atau banyak baris di Tabel B.
Mari kita perhatikan contoh di atas. JikaEmployee dan DepartmentBerada dalam arah searah terbalik, relasinya adalah relasi Many-To-One. Buat proyek JPA dalam IDE eclipse bernamaJPA_Eclipselink_OTM. Semua modul proyek ini ditampilkan sebagai berikut:
Membuat Entitas
Ikuti diagram yang diberikan di atas untuk membuat entitas. Buat paket bernama‘com.tutorialspoin.eclipselink.entity’ dibawah ‘src’paket. Buat kelas bernamaDepartment.javadi bawah paket yang diberikan. Entitas Departemen kelas ditampilkan sebagai berikut:
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;
}
}
Buat entitas kedua dalam relasi ini kelas entitas -Employee, bernama Employee.java dibawah ‘com.tutorialspoint.eclipselink.entity’paket. Kelas entitas Karyawan ditampilkan sebagai berikut:
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
Persistence.xml akan dibuat oleh Gerhana IDE saat membuat Proyek JPA. Detail konfigurasi adalah spesifikasi pengguna. File persistence.xml ditampilkan sebagai berikut:
<?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>
Kelas Layanan
Modul ini berisi kelas layanan, yang mengimplementasikan bagian relasional menggunakan inisialisasi atribut. Buat paket di bawah‘src’ paket bernama ‘com.tutorialspoint.eclipselink.service’. Kelas DAO bernamaOneToMany.javadibuat di bawah paket yang diberikan. Kelas DAO ditampilkan sebagai berikut:
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();
}
}
Setelah kompilasi dan eksekusi program di atas, Anda akan mendapatkan notifikasi di panel konsol Eclipse IDE. Untuk output, periksa meja kerja MySQL sebagai berikut. Dalam proyek ini tiga tabel dibuat.
Teruskan kueri berikut di antarmuka MySQL dan hasil department_employee tabel dalam format tabel diperlihatkan sebagai berikut dalam kueri:
Select * from department_Id;
Department_Id Employee_Eid
254 251
254 252
254 253
Pada tabel di atas, kolom deparment_id dan employee_id adalah kunci asing (kolom referensi) dari tabel departemen dan karyawan.
Lewati kueri berikut di antarmuka MySQL dan hasil tabel departemen dalam format tabel ditampilkan sebagai berikut dalam kueri:
Select * from department;
Id Name
254 Development
Lewati kueri berikut di antarmuka MySQL dan hasil tabel karyawan dalam format tabel ditampilkan sebagai berikut dalam kueri:
Select * from employee;
Eid Deg Ename Salary
251 Technical Writer Satish 45000
252 Technical Writer Krishna 45000
253 Technical Writer Masthanvali 50000
@OneToOne Relation
Dalam hubungan One-To-One, satu item hanya dapat dimiliki oleh satu item lainnya. Ini berarti setiap baris dari satu entitas dirujuk ke satu dan hanya satu baris dari entitas lain.
Mari kita perhatikan contoh di atas. Employee dan Departmentdalam cara searah terbalik, relasinya adalah relasi One-To-One. Artinya setiap karyawan hanya dimiliki oleh satu departemen. Buat proyek JPA dalam IDE eclipse bernamaJPA_Eclipselink_OTO. Semua modul proyek ini ditampilkan sebagai berikut:
Membuat Entitas
Ikuti diagram yang diberikan di atas untuk membuat entitas. Buat paket bernama‘com.tutorialspoin.eclipselink.entity’ dibawah ‘src’paket. Buat kelas bernamaDepartment.javadi bawah paket yang diberikan. Entitas Departemen kelas ditampilkan sebagai berikut:
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;
}
}
Buat entitas kedua dalam relasi ini kelas entitas -Employee, bernama Employee.java dibawah ‘com.tutorialspoint.eclipselink.entity’paket. Kelas entitas Karyawan ditampilkan sebagai berikut:
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 akan dibuat oleh Gerhana IDE saat membuat Proyek JPA. Detail konfigurasi adalah spesifikasi pengguna. File persistence.xml ditampilkan sebagai berikut:
<?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>
Kelas Layanan
Modul ini berisi kelas layanan, yang mengimplementasikan bagian relasional menggunakan inisialisasi atribut. Buat paket di bawah‘src’ paket bernama ‘com.tutorialspoint.eclipselink.service’. Kelas DAO bernamaOneToOne.javadibuat di bawah paket yang diberikan. Kelas DAO ditampilkan sebagai berikut:
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();
}
}
Setelah kompilasi dan eksekusi program di atas, Anda akan mendapatkan notifikasi di panel konsol Eclipse IDE. Untuk output, periksa meja kerja MySQL sebagai berikut. Dalam contoh di atas, dua tabel dibuat.
Teruskan kueri berikut di antarmuka MySQL dan hasil department tabel dalam format tabel diperlihatkan sebagai berikut dalam kueri:
Select * from department
Id Name
301 Development
Teruskan kueri berikut di antarmuka MySQL dan hasil employee tabel dalam format tabel diperlihatkan sebagai berikut dalam kueri:
Select * from employee
Eid Deg Ename Salary Department_id
302 Technical Writer Satish 45000 301
@ManyTany Relation
Hubungan Banyak-Ke-Banyak adalah tempat satu atau beberapa baris dari satu entitas dikaitkan dengan lebih dari satu baris di entitas lain.
Mari kita pertimbangkan contoh relasi antara entitas Kelas dan Guru. Secara dua arah, Kelas dan Guru memiliki hubungan Banyak-Ke-Satu. Itu berarti setiap catatan Kelas dirujuk oleh kumpulan Guru (id guru), yang seharusnya menjadi kunci utama dalam tabel Guru dan disimpan dalam tabel KelasGuru dan sebaliknya. Di sini, tabel Teachers_Class berisi kedua bidang Kunci asing. Buat proyek JPA dalam IDE eclipse bernamaJPA_Eclipselink_MTM. Semua modul proyek ini ditampilkan sebagai berikut:
Membuat Entitas
Ikuti diagram yang diberikan di atas untuk membuat entitas. Buat paket bernama‘com.tutorialspoin.eclipselink.entity’ dibawah ‘src’paket. Buat kelas bernamaClas.javadi bawah paket yang diberikan. Entitas Departemen kelas ditampilkan sebagai berikut:
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;
}
}
Buat entitas kedua dalam relasi ini kelas entitas -Employee, bernama Teacher.java dibawah ‘com.tutorialspoint.eclipselink.entity’paket. Kelas entitas Karyawan ditampilkan sebagai berikut:
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 akan dibuat oleh eclipse IDE saat menjalankan Proyek JPA. Detail konfigurasi adalah spesifikasi pengguna. File persistence.xml ditampilkan sebagai berikut:
<?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>
Kelas Layanan
Modul ini berisi kelas layanan, yang mengimplementasikan bagian relasional menggunakan inisialisasi atribut. Buat paket di bawah‘src’ paket bernama ‘com.tutorialspoint.eclipselink.service’. Kelas DAO bernamaManyToMany.javadibuat di bawah paket yang diberikan. Kelas DAO ditampilkan sebagai berikut:
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( );
}
}
Setelah kompilasi dan eksekusi program di atas, Anda akan mendapatkan notifikasi di panel konsol Eclipse IDE. Untuk output, periksa meja kerja MySQL sebagai berikut. Dalam proyek contoh ini, tiga tabel dibuat.
Teruskan kueri berikut di antarmuka MySQL dan hasil teacher_clas tabel dalam format tabel diperlihatkan sebagai berikut dalam kueri.
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
Pada tabel di atas, teacher_tid adalah kunci asing dari tabel guru, dan classet_cid adalah kunci asing dari tabel kelas. Oleh karena itu, guru yang berbeda dialokasikan untuk kelas yang berbeda.
Lewati kueri berikut di antarmuka MySQL dan hasil tabel guru dalam format tabel ditampilkan sebagai berikut dalam kueri:
Select * from teacher;
Tid Subject Tname
354 Java Satish
355 Adv Java Krishna
356 DB2 Masthanvali
Teruskan kueri berikut di antarmuka MySQL dan hasil clas tabel dalam format tabel diperlihatkan sebagai berikut dalam kueri:
Select * from clas;
cid Cname
351 1st
352 2nd
353 3rd