JPA - Pemetaan Lanjutan

JPA adalah library yang dirilis dengan spesifikasi java. Oleh karena itu, mendukung semua konsep berorientasi objek untuk persistensi entitas. Sampai sekarang kita selesai dengan dasar-dasar pemetaan relasional objek. Bab ini membawa Anda melalui pemetaan lanjutan antara objek dan entitas relasional.

Strategi Warisan

Pewarisan adalah konsep inti dari bahasa berorientasi objek, oleh karena itu kita dapat menggunakan hubungan atau strategi pewarisan antar entitas. JPA mendukung tiga jenis strategi warisan seperti SINGLE_TABLE, JOINED_TABLE, dan TABLE_PER_CONCRETE_CLASS.

Mari kita pertimbangkan contoh kelas Staff, TeachingStaff, NonTeachingStaff dan hubungannya sebagai berikut:

Pada diagram yang ditunjukkan di atas, Staff adalah entitas dan TeachingStaff dan NonTeachingStaff adalah sub entitas dari Staff. Di sini kita akan membahas contoh di atas dalam ketiga strategi pewarisan.

Strategi Meja Tunggal

Strategi Tabel Tunggal menggunakan semua bidang kelas (super dan sub kelas) dan memetakannya ke dalam satu tabel yang dikenal sebagai strategi SINGLE_TABLE. Di sini nilai diskriminator memainkan peran kunci dalam membedakan nilai dari tiga entitas dalam satu tabel.

Mari kita perhatikan contoh di atas, TeachingStaff dan NonTeachingStaff adalah sub kelas Staff. Ingatkan konsep pewarisan (adalah mekanisme mewarisi properti kelas super menurut sub kelas) dan oleh karena itu sid, sname adalah bidang yang dimiliki oleh TeachingStaff dan NonTeachingStaff. Buat proyek JPA. Semua modul proyek ini sebagai berikut:

Membuat Entitas

Buat paket bernama ‘com.tutorialspoint.eclipselink.entity’ dibawah ‘src’paket. Buat kelas java baru bernamaStaff.javadi bawah paket yang diberikan. Kelas entitas Staf ditampilkan sebagai berikut:

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;
   }
}

Pada kode di atas @DescriminatorColumn menentukan nama bidang (type) dan nilai itu menunjukkan bidang (Pengajaran dan NonTeachingStaff) yang tersisa.

Buat subclass (kelas) ke kelas Staf bernama TeachingStaff.java di bawah com.tutorialspoint.eclipselink.entitypaket. Kelas Entitas TeachingStaff ditampilkan sebagai berikut:

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;
   }
}

Buat subclass (kelas) ke kelas Staf bernama NonTeachingStaff.java di bawah com.tutorialspoint.eclipselink.entitypaket. Kelas Entitas NonTeachingStaff ditampilkan sebagai berikut:

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

File Persistence.xml berisi informasi konfigurasi database dan informasi pendaftaran kelas entitas. File 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.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>

Kelas layanan

Kelas layanan adalah bagian implementasi dari komponen bisnis. Buat paket di bawah‘src’ paket bernama ‘com.tutorialspoint.eclipselink.service’.

Buat kelas bernama SaveClient.java di bawah paket yang diberikan untuk menyimpan bidang kelas Staff, TeachingStaff, dan NonTeachingStaff. Kelas SaveClient ditampilkan sebagai berikut:

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();
   }
}

Setelah kompilasi dan eksekusi program di atas, Anda akan mendapatkan notifikasi di panel konsol Eclipse IDE. Periksa meja kerja MySQL untuk keluaran. Output dalam format tabel ditampilkan sebagai berikut:

Sid Tipe Nama S Keahlian daerah Kualifikasi Keahlian subjek
1 TS Gopal MSC MED Matematika
2 TS Manisha Tempat tidur BSC Inggris
3 NS Satish Akun
4 NS Krishna Admin Kantor

Akhirnya Anda akan mendapatkan tabel tunggal yang berisi ketiga bidang kelas dan berbeda dengan kolom diskriminator bernama ‘Type’ (bidang).

Strategi meja bergabung

Strategi tabel gabungan adalah membagikan kolom referensi yang berisi nilai-nilai unik untuk bergabung dengan tabel dan memudahkan transaksi. Mari kita perhatikan contoh yang sama seperti di atas.

Buat Proyek JPA. Semua modul proyek ditampilkan sebagai berikut:

Membuat Entitas

Buat paket bernama ‘com.tutorialspoint.eclipselink.entity’ dibawah ‘src’paket. Buat kelas java baru bernamaStaff.javadi bawah paket yang diberikan. Kelas entitas Staf ditampilkan sebagai berikut:

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;
   }
}

Buat subclass (kelas) ke kelas Staf bernama TeachingStaff.java di bawah com.tutorialspoint.eclipselink.entitypaket. Kelas Entitas TeachingStaff ditampilkan sebagai berikut:

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;
   }
}

Buat subclass (kelas) ke kelas Staf bernama NonTeachingStaff.java di bawah com.tutorialspoint.eclipselink.entitypaket. Kelas Entitas NonTeachingStaff ditampilkan sebagai berikut:

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

File Persistence.xml berisi informasi konfigurasi database dan informasi pendaftaran kelas entitas. File 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.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>

Kelas layanan

Kelas layanan adalah bagian implementasi dari komponen bisnis. Buat paket di bawah‘src’ paket bernama ‘com.tutorialspoint.eclipselink.service’.

Buat kelas bernama SaveClient.java di bawah paket yang diberikan untuk menyimpan bidang kelas Staff, TeachingStaff, dan NonTeachingStaff. Kemudian kelas SaveClient sebagai berikut:

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();
   }
}

Setelah kompilasi dan eksekusi program di atas, Anda akan mendapatkan notifikasi di panel konsol Eclipse IDE. Untuk output, periksa meja kerja MySQL sebagai berikut:

Di sini tiga tabel dibuat dan hasil dari staff tabel dalam format tabel ditampilkan sebagai berikut:

Sid Dtype Nama S
1 Tim pengajar Gopal
2 Tim pengajar Manisha
3 NonTeachingStaff Satish
4 NonTeachingStaff Krishna

Hasil dari TeachingStaff tabel dalam format tabel ditampilkan sebagai berikut:

Sid Kualifikasi Keahlian subjek
1 MSC MED Matematika
2 Tempat tidur BSC Inggris

Dalam sid tabel di atas adalah kunci asing (tabel staf formulir referensi lapangan) Hasil NonTeachingStaff tabel dalam format tabel ditampilkan sebagai berikut:

Sid Keahlian daerah
3 Akun
4 Admin Kantor

Terakhir, ketiga tabel dibuat menggunakan bidangnya masing-masing dan bidang SID digunakan bersama oleh ketiga tabel tersebut. Di tabel staf SID adalah kunci utama, di tabel lainnya (TeachingStaff dan NonTeachingStaff) SID adalah kunci asing.

Tabel per strategi kelas

Strategi tabel per kelas adalah membuat tabel untuk setiap sub entitas. Tabel staf akan dibuat tetapi akan berisi catatan nol. Nilai bidang tabel Staf harus dibagikan dengan tabel TeachingStaff dan NonTeachingStaff.

Mari kita perhatikan contoh yang sama seperti di atas. Semua modul proyek ini ditampilkan sebagai berikut:

Membuat Entitas

Buat paket bernama ‘com.tutorialspoint.eclipselink.entity’ dibawah ‘src’paket. Buat kelas java baru bernamaStaff.javadi bawah paket yang diberikan. Kelas entitas Staf ditampilkan sebagai berikut:

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;
   }
}

Buat subclass (kelas) ke kelas Staf bernama TeachingStaff.java di bawah com.tutorialspoint.eclipselink.entitypaket. Kelas Entitas TeachingStaff ditampilkan sebagai berikut:

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;
   }
}

Buat subclass (kelas) ke kelas Staf bernama NonTeachingStaff.java di bawah com.tutorialspoint.eclipselink.entitypaket. Kelas Entitas NonTeachingStaff ditampilkan sebagai berikut:

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

File Persistence.xml berisi informasi konfigurasi database dan informasi pendaftaran kelas entitas. File 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.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>

Kelas layanan

Kelas layanan adalah bagian implementasi dari komponen bisnis. Buat paket di bawah‘src’ paket bernama ‘com.tutorialspoint.eclipselink.service’.

Buat kelas bernama SaveClient.javadi bawah paket yang diberikan untuk menyimpan bidang kelas Staff, TeachingStaff, dan NonTeachingStaff. Kelas SaveClient ditampilkan sebagai berikut:

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();
   }
}

Setelah kompilasi dan eksekusi program di atas, Anda akan mendapatkan notifikasi di panel konsol Eclipse IDE. Untuk keluaran, periksa meja kerja MySQL sebagai berikut:

Di sini tiga tabel dibuat dan Staff tabel berisi catatan nol.

Hasil dari TeachingStaff dalam format tabel ditampilkan sebagai berikut:

Sid Kualifikasi Nama S Keahlian subjek
1 MSC MED Gopal Matematika
2 Tempat tidur BSC Manisha Inggris

Tabel di atas TeachingStaff berisi bidang Entitas Staf dan Staf Pengajar.

Hasil dari NonTeachingStaff dalam format tabel ditampilkan sebagai berikut:

Sid Keahlian daerah Nama S
3 Akun Satish
4 Admin Kantor Krishna

Tabel di atas NonTeachingStaff berisi bidang Entitas Staff dan NonTeachingStaff.