JPA - Panduan Cepat

Setiap aplikasi perusahaan melakukan operasi database dengan menyimpan dan mengambil data dalam jumlah besar. Terlepas dari semua teknologi yang tersedia untuk manajemen penyimpanan, pengembang aplikasi biasanya berjuang untuk melakukan operasi database secara efisien.

Umumnya, pengembang Java menggunakan banyak kode, atau menggunakan kerangka kerja berpemilik untuk berinteraksi dengan database, sedangkan menggunakan JPA, beban interaksi dengan database berkurang secara signifikan. Ini membentuk jembatan antara model objek (program Java) dan model relasional (program database).

Ketidaksesuaian antara model relasional dan objek

Objek relasional direpresentasikan dalam format tabel, sedangkan model objek direpresentasikan dalam grafik format objek yang saling berhubungan. Saat menyimpan dan mengambil model objek dari database relasional, beberapa ketidakcocokan terjadi karena alasan berikut:

  • Granularity : Model objek memiliki lebih banyak perincian daripada model relasional.

  • Subtypes : Subtipe (berarti warisan) tidak didukung oleh semua jenis database relasional.

  • Identity : Seperti model objek, model relasional tidak mengekspos identitas sambil menulis persamaan.

  • Associations : Model relasional tidak dapat menentukan beberapa hubungan saat melihat ke model domain objek.

  • Data navigation : Navigasi data antar objek dalam jaringan objek berbeda pada kedua model.

Apa itu JPA?

Java Persistence API adalah kumpulan kelas dan metode untuk terus-menerus menyimpan sejumlah besar data ke dalam database yang disediakan oleh Oracle Corporation.

Dimana menggunakan JPA?

Untuk mengurangi beban penulisan kode untuk manajemen objek relasional, programmer mengikuti kerangka kerja 'JPA Provider', yang memungkinkan interaksi yang mudah dengan instance database. Di sini kerangka kerja yang diperlukan diambil alih oleh JPA.

Sejarah JPA

Versi EJB sebelumnya, lapisan ketekunan yang ditentukan dikombinasikan dengan lapisan logika bisnis menggunakan Antarmuka javax.ejb.EntityBean.

  • Saat memperkenalkan EJB 3.0, lapisan persistensi dipisahkan dan ditetapkan sebagai JPA 1.0 (Java Persistence API). Spesifikasi API ini dirilis bersamaan dengan spesifikasi JAVA EE5 pada 11 Mei 2006 menggunakan JSR 220.

  • JPA 2.0 dirilis dengan spesifikasi JAVA EE6 pada 10 Desember 2009 sebagai bagian dari Java Community Process JSR 317.

  • JPA 2.1 dirilis dengan spesifikasi JAVA EE7 pada 22 April 2013 menggunakan JSR 338.

Penyedia JPA

JPA adalah API open source, oleh karena itu berbagai vendor perusahaan seperti Oracle, Redhat, Eclipse, dll. Menyediakan produk baru dengan menambahkan rasa persistensi JPA di dalamnya. Beberapa dari produk ini meliputi:

Hibernate, Eclipselink, Toplink, Spring Data JPA, etc.

Java Persistence API adalah sumber untuk menyimpan entitas bisnis sebagai entitas relasional. Ini menunjukkan bagaimana mendefinisikan OBYEK JAWA LAMA TANAH (POJO) sebagai entitas dan bagaimana mengelola entitas dengan relasi.

Arsitektur Tingkat Kelas

Gambar berikut menunjukkan arsitektur tingkat kelas JPA. Ini menunjukkan kelas inti dan antarmuka JPA.

Tabel berikut menjelaskan masing-masing unit yang ditunjukkan pada arsitektur di atas.

Unit Deskripsi
EntityManagerFactory Ini adalah kelas pabrik dari EntityManager. Ini membuat dan mengelola beberapa instance EntityManager.
EntityManager Ini adalah Antarmuka, ia mengelola operasi ketekunan pada objek. Ia bekerja seperti pabrik untuk contoh Query.
Entity Entitas adalah objek persistensi, disimpan sebagai catatan dalam database.
EntityTransaction Ini memiliki hubungan satu-ke-satu dengan EntityManager. Untuk setiap EntityManager, operasi dipertahankan oleh kelas EntityTransaction.
Persistence Kelas ini berisi metode statis untuk mendapatkan instance EntityManagerFactory.
Query Antarmuka ini diimplementasikan oleh setiap vendor JPA untuk mendapatkan objek relasional yang memenuhi kriteria.

Kelas dan antarmuka di atas digunakan untuk menyimpan entitas ke dalam database sebagai catatan. Mereka membantu pemrogram dengan mengurangi upaya mereka menulis kode untuk menyimpan data ke dalam database sehingga mereka dapat berkonsentrasi pada aktivitas yang lebih penting seperti menulis kode untuk memetakan kelas dengan tabel database.

Hubungan Kelas JPA

Dalam arsitektur di atas, hubungan antara kelas dan antarmuka adalah milik paket javax.persistence. Diagram berikut menunjukkan hubungan di antara mereka.

  • Hubungan antara EntityManagerFactory dan EntityManager adalah one-to-many. Ini adalah kelas pabrik untuk instance EntityManager.

  • Hubungan antara EntityManager dan EntityTransaction adalah one-to-one. Untuk setiap operasi EntityManager, ada instance EntityTransaction.

  • Hubungan antara EntityManager dan Query adalah one-to-many. Banyak kueri yang dapat dieksekusi menggunakan satu instance EntityManager.

  • Hubungan antara EntityManager dan Entity adalah one-to-many. Satu instance EntityManager dapat mengelola banyak Entitas.

Sebagian besar aplikasi kontemporer menggunakan database relasional untuk menyimpan data. Baru-baru ini, banyak vendor beralih ke database objek untuk mengurangi beban pemeliharaan data. Artinya, database objek atau teknologi relasional objek menangani penyimpanan, pengambilan, pembaruan, dan pemeliharaan data. Bagian inti dari teknologi relasional objek ini adalah memetakan file orm.xml. Karena xml tidak memerlukan kompilasi, kami dapat dengan mudah membuat perubahan pada beberapa sumber data dengan sedikit administrasi.

Pemetaan Relasional Objek

Pemetaan Relasional Objek (ORM) secara singkat memberi tahu Anda tentang apa itu ORM dan cara kerjanya. ORM adalah kemampuan pemrograman untuk mengubah data dari tipe objek ke tipe relasional dan sebaliknya.

Fitur utama ORM adalah memetakan atau mengikat objek ke datanya di database. Saat melakukan pemetaan, kita harus mempertimbangkan data, jenis data, dan hubungannya dengan self-entity atau entity di tabel lain.

Fitur lanjutan

  • Idiomatic persistence : Ini memungkinkan Anda untuk menulis kelas ketekunan menggunakan kelas berorientasi objek.

  • High Performance : Ini memiliki banyak teknik pengambilan dan teknik penguncian yang penuh harapan.

  • Reliable : Ini sangat stabil dan digunakan oleh banyak programmer profesional.

Arsitektur ORM

Arsitektur ORM terlihat sebagai berikut.

Arsitektur di atas menjelaskan bagaimana data objek disimpan ke dalam database relasional dalam tiga fase.

Fase1

Fase pertama, dinamakan sebagai object data phase, berisi kelas POJO, antarmuka layanan, dan kelas. Ini adalah lapisan komponen bisnis utama, yang memiliki operasi dan atribut logika bisnis.

Misalnya mari kita ambil database karyawan sebagai skema.

  • Kelas POJO karyawan berisi atribut seperti ID, nama, gaji, dan penunjukan. Ini juga berisi metode seperti penyetel dan pengambil atribut tersebut.

  • Kelas DAO / Layanan karyawan berisi metode layanan seperti buat karyawan, temukan karyawan, dan hapus karyawan.

Tahap 2

Fase kedua, dinamai sebagai mapping atau persistence phase, berisi penyedia JPA, file pemetaan (ORM.xml), JPA Loader, dan Object Grid.

  • JPA Provider: Ini adalah produk vendor yang mengandung rasa JPA (javax.persistence). Misalnya Eclipselink, Toplink, Hibernate, dll.

  • Mapping file : File pemetaan (ORM.xml) berisi konfigurasi pemetaan antara data dalam kelas POJO dan data dalam database relasional.

  • JPA Loader: JPA loader bekerja seperti memori cache. Itu dapat memuat data grid relasional. Ia bekerja seperti salinan database untuk berinteraksi dengan kelas layanan untuk data POJO (atribut kelas POJO).

  • Object Grid: Ini adalah lokasi sementara yang dapat menyimpan salinan data relasional, seperti memori cache. Semua kueri terhadap database pertama-tama dilakukan pada data di kisi objek. Hanya setelah itu dilakukan, itu mempengaruhi database utama.

Tahap 3

Fase ketiga adalah relational data phase. Ini berisi data relasional yang terhubung secara logis ke komponen bisnis. Seperti dibahas di atas, hanya jika komponen bisnis melakukan data, data disimpan ke dalam database secara fisik. Sampai saat itu, data yang dimodifikasi disimpan dalam memori cache sebagai format kisi. Proses mendapatkan data identik dengan proses penyimpanan data.

Mekanisme interaksi terprogram dari tiga fase di atas disebut sebagai object relational mapping.

Mapping.xml

File mapping.xml adalah untuk menginstruksikan vendor JPA untuk memetakan kelas Entitas dengan tabel database.

Mari kita ambil contoh entitas Karyawan yang berisi empat atribut. Kelas POJO dari entitas Karyawan bernamaEmployee.java adalah sebagai berikut:

public class Employee 
{
	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;
	}
}

Kode di atas adalah kelas POJO entitas Karyawan. Ini berisi empat atributeid, ename, salary, dan deg. Pertimbangkan atribut ini sebagai bidang tabel dalam tabel daneidsebagai kunci utama dari tabel ini. Sekarang kita harus mendesain file pemetaan hibernate untuk itu. File pemetaan bernamamapping.xml adalah sebagai berikut:

<? xml version="1.0" encoding="UTF-8" ?>
<entity-mappings xmlns="http://java.sun.com/xml/ns/persistence/orm"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/persistence/orm    
                        http://java.sun.com/xml/ns/persistence/orm_1_0.xsd"
                        version="1.0">
    <description> XML Mapping file</description>
    <entity class="Employee">        
        <table name="EMPLOYEETABLE"/>
        <attributes>
            <id name="eid">
                <generated-value strategy="TABLE"/>
            </id>
            <basic name="ename">
                <column name="EMP_NAME" length="100"/>
            </basic>
            <basic name="salary">
            </basic>
            <basic name="deg">
            </basic>
        </attributes>
    </entity>
</entity-mappings>

Skrip di atas digunakan untuk memetakan kelas entitas dengan tabel database. Di file ini

  • <entity-mappings> : tag mendefinisikan definisi skema untuk mengizinkan tag entitas ke dalam file xml.

  • <description> : tag memberikan penjelasan tentang aplikasi.

  • <entity>: tag mendefinisikan kelas entitas yang ingin Anda ubah menjadi tabel dalam database. Kelas atribut mendefinisikan nama kelas entitas POJO.

  • <table>: tag mendefinisikan nama tabel. Jika Anda ingin memiliki nama yang identik untuk kelas dan tabel, maka tag ini tidak diperlukan.

  • <attributes> : tag mendefinisikan atribut (bidang dalam tabel).

  • <id>: tag mendefinisikan kunci utama dari tabel. Itu<generated-value> tag mendefinisikan cara menetapkan nilai kunci utama seperti Automatic, Manual, atau diambil dari Sequence.

  • <basic> : tag digunakan untuk menentukan atribut yang tersisa untuk tabel.

  • <column-name> : tag digunakan untuk menentukan nama field tabel yang ditentukan pengguna dalam tabel.

Anotasi

Umumnya file xml digunakan untuk mengkonfigurasi komponen tertentu, atau memetakan dua spesifikasi komponen yang berbeda. Dalam kasus kami, kami harus memelihara file xml secara terpisah dalam kerangka kerja. Itu berarti saat menulis file pemetaan xml, kita perlu membandingkan atribut kelas POJO dengan tag entitas di file mapping.xml.

Inilah solusinya. Dalam definisi kelas, kita dapat menulis bagian konfigurasi menggunakan anotasi. Anotasi digunakan untuk kelas, properti, dan metode. Anotasi dimulai dengan simbol '@'. Anotasi dideklarasikan sebelum kelas, properti, atau metode. Semua anotasi JPA ditentukan dijavax.persistence paket.

Berikut daftar anotasi yang digunakan dalam contoh kami diberikan di bawah ini.

Anotasi Deskripsi
@Kesatuan Mendeklarasikan kelas sebagai entitas atau tabel.
@Meja Menyatakan nama tabel.
@Dasar Menentukan bidang non-kendala secara eksplisit.
@Bayu_joo Menentukan properti kelas atau entitas yang nilainya merupakan turunan dari kelas yang dapat disematkan.
@Indo Menentukan properti, gunakan untuk identitas (kunci utama tabel) kelas.
@GeneratedValue Menentukan bagaimana atribut identitas dapat diinisialisasi seperti otomatis, manual, atau nilai yang diambil dari tabel urutan.
@Sementara Menentukan properti yang tidak persisten, yaitu nilai tidak pernah disimpan dalam database.
@Kolom Menentukan atribut kolom untuk properti persistensi.
@Sequence Menentukan nilai untuk properti yang ditentukan dalam anotasi @GeneratedValue. Ini menciptakan urutan.
@Generator Meja Menentukan penghasil nilai untuk properti yang ditentukan dalam anotasi @GeneratedValue. Ini menciptakan tabel untuk menghasilkan nilai.
@Akses Jenis Jenis anotasi ini digunakan untuk menyetel jenis akses. Jika Anda menyetel @AccessType (FIELD), maka akses terjadi secara bijaksana. Jika Anda menyetel @AccessType (PROPERTI), maka akses akan muncul dari segi Properti.
@Bergabunglah Menentukan asosiasi entitas atau kumpulan entitas. Ini digunakan dalam asosiasi banyak-ke-satu dan satu-ke-banyak.
@Bayu_joo Menentukan bidang dan batasan unik untuk tabel utama atau sekunder.
@Solusiholcim Referensi nama kolom dalam kueri SQL menggunakan klausa pilih.
@Banyak ke banyak Mendefinisikan hubungan banyak ke banyak antara Tabel gabungan.
@Bayu_joo Mendefinisikan hubungan banyak-ke-satu antara tabel gabungan.
@OneTany Mendefinisikan hubungan satu-ke-banyak antara tabel gabungan.
@OneTone Mendefinisikan hubungan satu-ke-satu antara tabel gabungan.
@Named menentukan daftar kueri bernama.
@Namedery Menentukan Query menggunakan nama statis.

Standar Kacang Java

Kelas Java merangkum nilai instance dan perilakunya ke dalam satu unit yang disebut objek. Java Bean adalah penyimpanan sementara dan komponen atau objek yang dapat digunakan kembali. Ini adalah kelas yang dapat serial yang memiliki konstruktor default dan metode pengambil dan penyetel untuk menginisialisasi atribut instance secara individual.

Konvensi Kacang

  • Bean berisi konstruktor default atau file yang berisi instance berseri. Oleh karena itu, kacang dapat membuat contoh kacang lainnya.

  • Properti kacang dapat dipisahkan menjadi properti Boolean atau properti non-Boolean.

  • Properti non-Boolean berisi getter dan setter metode.

  • Properti Boolean berisi setter dan is metode.

  • Getter metode properti apa pun harus dimulai dengan huruf kecil get(konvensi metode java) dan dilanjutkan dengan nama kolom yang diawali dengan huruf kapital. Misalnya, nama field adalahsalary oleh karena itu metode pengambil dari bidang ini adalah getSalary ().

  • Setter metode properti apa pun harus dimulai dengan huruf kecil set (konvensi metode java), dilanjutkan dengan nama kolom yang diawali dengan huruf kapital dan argument valueuntuk disetel ke bidang. Misalnya, nama field adalahsalary Oleh karena itu, metode penyetel bidang ini adalah setSalary ( double sal ).

  • Untuk properti Boolean, ismetode untuk memeriksa apakah itu benar atau salah. Misalnya properti Booleanempty, itu is metode bidang ini isEmpty ().

Bab ini memandu Anda melalui proses pengaturan JPA pada sistem berbasis Windows dan Linux. JPA dapat dengan mudah diinstal dan diintegrasikan dengan lingkungan Java Anda saat ini dengan mengikuti beberapa langkah sederhana tanpa prosedur penyiapan yang rumit. Administrasi pengguna diperlukan saat instalasi.

Persyaratan sistem

JDK Java SE 2 JDK 1.5 atau lebih tinggi
Penyimpanan RAM 1 GB (disarankan)
Ruang Disk Tidak ada persyaratan minimum
Versi Sistem Operasi Windows XP atau yang lebih baru, Linux

Sekarang mari kita lanjutkan dengan langkah-langkah untuk menginstal JPA.

Langkah 1: Verifikasi Instalasi Java Anda

Pertama-tama, Anda harus menginstal Java Software Development Kit (SDK) di sistem Anda. Untuk memverifikasi ini, jalankan salah satu dari dua perintah berikut tergantung pada platform yang Anda kerjakan.

Jika penginstalan Java sudah dilakukan dengan benar, maka versi dan spesifikasi penginstalan Java Anda saat ini akan ditampilkan. Output sampel diberikan dalam tabel berikut.

Peron Perintah Output Sampel
Windows

Buka konsol perintah dan ketik:

\>java –version

Versi Java "1.7.0_60"

Java (TM) SE Run Time Environment (build 1.7.0_60-b19)

Java Hotspot (TM) 64-bit Server VM (build 24.60-b09, mode campuran)

Linux

Buka terminal perintah dan ketik:

$java –version

versi java "1.7.0_25"

Buka JDK Runtime Environment (rhel-2.3.10.4.el6_4-x86_64)

Buka VM Server JDK 64-Bit (build 23.7-b01, mode campuran)

  • Kami berasumsi bahwa pembaca tutorial ini telah menginstal Java SDK versi 1.7.0_60 di sistem mereka.

  • Jika Anda tidak memiliki Java SDK, unduh versi saat ini dari http://www.oracle.com/technetwork/java/javase/downloads/index.html dan menginstalnya.

Langkah 2: Setel Lingkungan Java Anda

Setel variabel lingkungan JAVA_HOME agar mengarah ke lokasi direktori dasar tempat Java diinstal pada mesin Anda. Sebagai contoh,

Peron Deskripsi
Windows Setel JAVA_HOME ke C: \ ProgramFiles \ java \ jdk1.7.0_60
Linux Ekspor JAVA_HOME = / usr / local / java-current

Tambahkan jalur lengkap lokasi kompilator Java ke Jalur Sistem.

Peron Deskripsi
Windows Tambahkan String "C: \ Program Files \ Java \ jdk1.7.0_60 \ bin" ke bagian akhir PATH variabel sistem.
Linux Ekspor PATH = $ PATH: $ JAVA_HOME / bin /

Jalankan perintahnya java -version dari command prompt seperti dijelaskan di atas.

Langkah3: Menginstal JPA

Anda dapat melalui instalasi JPA dengan menggunakan Penyedia JPA mana pun dari tutorial ini, misalnya, Eclipselink, Hibernate. Mari kita ikuti instalasi JPA menggunakan Eclipselink. Untuk pemrograman JPA, kita harus mengikuti framework folder tertentu, oleh karena itu sebaiknya gunakan IDE.

Unduh formulir Eclipse IDE berikut tautan https://www.eclipse.org/downloads/ Pilih pengembang EclipseIDE untuk JavaEE Eclipse indigo.

Buka zip file zip Eclipse di drive C. Buka Eclipse IDE.

Menginstal JPA menggunakan Eclipselink

Eclipselink adalah pustaka sehingga kami tidak dapat menambahkannya langsung ke Eclipse IDE. Untuk menginstal JPA menggunakan Eclipselink Anda perlu mengikuti langkah-langkah yang diberikan di bawah ini.

  • Buat proyek JPA baru dengan memilih File->New->JPA Project di Eclipse IDE sebagai berikut:

  • Anda akan mendapatkan kotak dialog bernama New JPA Project. Masukkan nama proyektutorialspoint_JPA_Eclipselink, Periksalah jre versi dan klik berikutnya:

  • Klik perpustakaan unduhan (jika Anda tidak memiliki perpustakaan) di bagian perpustakaan pengguna.

  • Pilih versi terbaru pustaka Eclipselink di kotak dialog Unduh pustaka dan klik next sebagai berikut:

  • Terima persyaratan lisensi dan klik selesai untuk perpustakaan unduhan.

  • 6. Pengunduhan dimulai seperti yang ditunjukkan pada gambar layar berikut.

  • Setelah mengunduh, pilih perpustakaan yang diunduh di bagian perpustakaan pengguna dan klik selesai.

  • Akhirnya Anda mendapatkan file proyek di Package Explorerdi Eclipse IDE. Ekstrak semua file, Anda akan mendapatkan folder dan hierarki file sebagai berikut:

Menambahkan konektor MySQL ke Project

Setiap contoh yang kita diskusikan di sini membutuhkan konektivitas database. Mari kita pertimbangkan database MySQL untuk operasi database. Ini membutuhkan jar konektor mysql untuk berinteraksi dengan program Java.

Ikuti langkah-langkah untuk mengonfigurasi jar database dalam proyek Anda.

  • Pergi ke Properti proyek ->Java Build Path dengan klik kanan di atasnya. Anda akan mendapatkan kotak dialog seperti yang ditunjukkan pada tangkapan layar berikut. Klik Add External Jars.

  • Pergi ke lokasi jar di memori sistem Anda, pilih file dan klik buka.

  • Klik ok pada dialog properti. Anda akan mendapatkan Jar konektor MySQL ke dalam proyek Anda. Sekarang Anda dapat melakukan operasi database menggunakan MySQL.

Bab ini menggunakan contoh sederhana untuk mendemonstrasikan cara kerja JPA. Mari kita pertimbangkan Manajemen Karyawan sebagai contoh. Misalkan Manajemen Karyawan membuat, memperbarui, menemukan, dan menghapus catatan karyawan. Seperti yang disebutkan, kami menggunakan database MySQL untuk operasi database.

Modul utama untuk contoh ini adalah sebagai berikut:

  • Model or POJO

    Employee.java

  • Persistence

    Persistence.xml

  • Service

    CreatingEmployee.java

    UpdatingEmployee.java

    FindingEmployee.java

    DeletingEmployee.java

Mari kita ambil hierarki paket yang telah kita gunakan dalam instalasi JPA dengan Eclipselink. Ikuti hierarki untuk contoh ini seperti yang ditunjukkan di bawah ini:

Membuat Entitas

Entitas tidak lain adalah kacang atau model. Dalam contoh ini, kami akan menggunakanEmployee sebagai sebuah entitas. eid, ename, salary, dan degadalah atribut entitas ini. Ini berisi konstruktor default serta metode penyetel dan pengambil dari atribut tersebut.

Dalam hierarki yang ditunjukkan di atas, buat paket bernama ‘com.tutorialspoint.eclipselink.entity’, dibawah ‘src’(Sumber) paket. Buat kelas bernamaEmployee.java di bawah paket yang diberikan 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.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 + "]";
	}
}

Dalam kode di atas, kami telah menggunakan anotasi @Entity untuk menjadikan kelas POJO ini sebagai entitas.

Sebelum melanjutkan ke modul berikutnya kita perlu membuat database untuk entitas relasional, yang akan mendaftarkan database tersebut persistence.xmlmengajukan. Buka meja kerja MySQL dan ketik kueri berikut hte.

create database jpadb
use jpadb

Persistence.xml

Modul ini memainkan peran penting dalam konsep JPA. Dalam file xml ini kami akan mendaftarkan database dan menentukan kelas entitas.

Dalam hierarki paket yang ditunjukkan di atas, persistence.xml di bawah Paket konten JPA adalah 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>
	<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>

Di xml di atas, <persistence-unit> tag ditentukan dengan nama khusus untuk persistensi JPA. Itu<class>tag mendefinisikan kelas entitas dengan nama paket. Itu<properties> tag mendefinisikan semua properti, dan <property>tag mendefinisikan setiap properti seperti registrasi database, spesifikasi URL, username, dan password. Ini adalah properti Eclipselink. File ini akan mengkonfigurasi database.

Operasi Persistensi

Operasi persistensi digunakan untuk berinteraksi dengan database dan memang begitu load dan storeoperasi. Dalam komponen bisnis, semua operasi ketekunan termasuk dalam kelas layanan.

Dalam hierarki paket yang ditunjukkan di atas, buat paket bernama ‘com.tutorialspoint.eclipselink.service’, dibawah ‘src’(sumber) paket. Semua kelas layanan bernama CreateEmloyee.java, UpdateEmployee.java, FindEmployee.java, dan DeleteEmployee.java. berada di bawah paket yang diberikan sebagai berikut:

Buat Karyawan

Segmen kode berikut menunjukkan cara membuat kelas Karyawan bernama 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( );
	}
}

Pada kode di atas, createEntityManagerFactory ()membuat unit persistensi dengan memberikan nama unik yang sama yang kami berikan untuk persistence-unit di file persistent.xml. Ituentitymanagerfactory objek akan membuat entitymanger Misalnya dengan menggunakan createEntityManager ()metode. Ituentitymanager objek menciptakan entitytransactionMisalnya untuk manajemen transaksi. Dengan menggunakanentitymanager objek, kita dapat mempertahankan entitas ke dalam database.

Setelah kompilasi dan eksekusi program di atas, Anda akan mendapatkan notifikasi dari eclipselink library pada panel konsol eclipse IDE.

Hasilnya, buka meja kerja MySQL dan ketik kueri berikut.

use jpadb
select * from employee

Tabel database yang terpengaruh bernama employee akan ditampilkan dalam format tabel sebagai berikut:

Idul Fitri Ename Gaji Deg
1201 Gopal 40000 Manajer teknis

Perbarui Karyawan

Untuk memperbarui catatan seorang karyawan, kita perlu mengambil catatan yang ada dari database, membuat perubahan, dan terakhir memasukkannya ke database. Kelas bernamaUpdateEmployee.java 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.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();
	}
}

Setelah kompilasi dan eksekusi program di atas, Anda akan mendapatkan notifikasi dari library Eclipselink di panel konsol eclipse IDE.

Hasilnya, buka meja kerja MySQL dan ketik kueri berikut.

use jpadb
select * from employee

Tabel database yang terpengaruh bernama employee akan ditampilkan dalam format tabel sebagai berikut:

Idul Fitri Ename Gaji Deg
1201 Gopal 46000 Manajer teknis

Gaji karyawan, 1201 diperbarui menjadi 46000.

Temukan Karyawan

Untuk menemukan catatan seorang karyawan, kita harus mengambil data yang ada dari database dan menampilkannya. Dalam operasi ini, EntityTransaction tidak diterapkan saat mengambil rekaman.

Kelas bernama FindEmployee.java sebagai berikut.

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

Setelah mengkompilasi dan menjalankan program di atas, Anda akan mendapatkan output berikut dari library Eclipselink di panel konsol eclipse IDE.

employee ID = 1201
employee NAME = Gopal
employee SALARY = 46000.0
employee DESIGNATION = Technical Manager

Menghapus Karyawan

Untuk menghapus catatan seorang karyawan, pertama kita akan menemukan catatan yang ada dan kemudian menghapusnya. Di sini EntityTransaction memainkan peran penting.

Kelas bernama DeleteEmployee.java sebagai berikut:

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

Setelah kompilasi dan eksekusi program di atas, Anda akan mendapatkan notifikasi dari library Eclipselink di panel konsol eclipse IDE.

Hasilnya, buka meja kerja MySQL dan ketik kueri berikut.

use jpadb
select * from employee

Database yang terkena dampak bernama employee akan memiliki catatan nol.

Setelah menyelesaikan semua modul dalam contoh ini, paket dan hierarki file terlihat seperti berikut:

Bab ini menjelaskan tentang JPQL dan cara kerjanya dengan unit persistensi. Dalam bab ini, contoh yang diberikan mengikuti hierarki paket yang sama, yang kita gunakan di bab sebelumnya.

Bahasa Kueri Persistensi Java

JPQL adalah singkatan dari Java Persistence Query Language. Ini digunakan untuk membuat kueri terhadap entitas yang akan disimpan dalam database relasional. JPQL dikembangkan berdasarkan sintaks SQL. Tapi itu tidak akan mempengaruhi database secara langsung.

JPQL dapat mengambil data menggunakan klausa SELECT, dapat melakukan pembaruan massal menggunakan klausa UPDATE dan klausa DELETE.

Struktur Kueri

Sintaks JPQL sangat mirip dengan sintaks SQL. Memiliki sintaks seperti SQL adalah keuntungan karena SQL sederhana dan banyak digunakan. SQL bekerja secara langsung terhadap tabel, catatan, dan bidang database relasional, sedangkan JPQL bekerja dengan kelas dan instance Java.

Misalnya, kueri JPQL bisa mengambil objek entitas daripada hasil bidang yang ditetapkan dari database, seperti dengan SQL. Struktur query JPQL sebagai berikut.

SELECT ... FROM ...
[WHERE ...]
[GROUP BY ... [HAVING ...]]
[ORDER BY ...]

Struktur kueri JPQL DELETE dan UPDATE adalah sebagai berikut.

DELETE FROM ... [WHERE ...]
 
UPDATE ... SET ... [WHERE ...]

Fungsi Skalar dan Agregat

Fungsi skalar mengembalikan nilai yang dihasilkan berdasarkan nilai masukan. Fungsi agregat mengembalikan nilai yang dihasilkan dengan menghitung nilai input.

Kami akan menggunakan contoh Manajemen Karyawan yang sama seperti pada bab sebelumnya. Di sini kita akan membahas kelas layanan menggunakan fungsi skalar dan agregat JPQL.

Mari kita asumsikan jpadb.employee tabel berisi catatan berikut.

Idul Fitri Ename Gaji Deg
1201 Gopal 40000 Manajer teknis
1202 Manisha 40000 Pembaca Bukti
1203 Masthanvali 40000 Penulis teknis
1204 Satish 30000 Penulis teknis
1205 Krishna 30000 Penulis teknis
1206 Kiran 35000 Pembaca Bukti

Buat kelas bernama ScalarandAggregateFunctions.java dibawah com.tutorialspoint.eclipselink.service paket sebagai berikut.

package com.tutorialspoint.eclipselink.service;

import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;

public class ScalarandAggregateFunctions 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager();
		//Scalar function
		Query query = entitymanager.
		createQuery("Select UPPER(e.ename) from Employee e");
		List<String> list=query.getResultList();
		
		for(String e:list)
		{
			System.out.println("Employee NAME :"+e);
		}
		//Aggregate function
		Query query1 = entitymanager.
				createQuery("Select MAX(e.salary) from Employee e");
		Double result=(Double) query1.getSingleResult();
		System.out.println("Max Employee Salary :"+result);
	}
}

Setelah kompilasi dan eksekusi program di atas, Anda akan mendapatkan output berikut pada panel konsol Eclipse IDE.

Employee NAME :GOPAL
Employee NAME :MANISHA
Employee NAME :MASTHANVALI
Employee NAME :SATISH
Employee NAME :KRISHNA
Employee NAME :KIRAN
ax Employee Salary :40000.0

Antara, Dan, Seperti Kata Kunci

Between, And, dan Likeadalah kata kunci utama JPQL. Kata kunci ini digunakan setelahWhere clause dalam sebuah pertanyaan.

Buat kelas bernama BetweenAndLikeFunctions.java dibawah com.tutorialspoint.eclipselink.service paket sebagai berikut:

package com.tutorialspoint.eclipselink.service;

import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
import com.tutorialspoint.eclipselink.entity.Employee;

public class BetweenAndLikeFunctions 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
			createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
			createEntityManager();
		//Between
		Query query = entitymanager.
			createQuery( "Select e " +
					     "from Employee e " +
					     "where e.salary " +
					     "Between 30000 and 40000" )
		List<Employee> list=(List<Employee>)query.getResultList( );
		 
		for( Employee e:list )
		{
			System.out.print("Employee ID :"+e.getEid( ));
			System.out.println("\t Employee salary :"+e.getSalary( ));
		}
		
		//Like
		Query query1 = entitymanager.
			createQuery("Select e " +
					    "from Employee e " +
					    "where e.ename LIKE 'M%'");
		List<Employee> list1=(List<Employee>)query1.getResultList( );
		for( Employee e:list1 )
		{
			System.out.print("Employee ID :"+e.getEid( ));
			System.out.println("\t Employee name :"+e.getEname( ));
		}
	}
}

Setelah mengkompilasi dan menjalankan program di atas, Anda akan mendapatkan output berikut di panel konsol Eclipse IDE.

Employee ID :1201	 Employee salary :40000.0
Employee ID :1202	 Employee salary :40000.0
Employee ID :1203	 Employee salary :40000.0
Employee ID :1204	 Employee salary :30000.0
Employee ID :1205	 Employee salary :30000.0
Employee ID :1206	 Employee salary :35000.0

Employee ID :1202	 Employee name :Manisha
Employee ID :1203	 Employee name :Masthanvali

Memerintah

Untuk memesan record dalam JPQL, kami menggunakan klausa ORDER BY. Penggunaan klausa ini sama seperti di SQL, tetapi berhubungan dengan entitas. Contoh berikut menunjukkan cara menggunakan klausa ORDER BY.

Buat kelas Ordering.java dibawah com.tutorialspoint.eclipselink.service paket sebagai berikut:

package com.tutorialspoint.eclipselink.service;

import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
import com.tutorialspoint.eclipselink.entity.Employee;

public class Ordering 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
			createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
			createEntityManager();
		//Between
		Query query = entitymanager.
			createQuery( "Select e " +
					     "from Employee e " +
					     "ORDER BY e.ename ASC" );
		List<Employee> list=(List<Employee>)query.getResultList( );
		 
		for( Employee e:list )
		{
			System.out.print("Employee ID :"+e.getEid( ));
			System.out.println("\t Employee Name :"+e.getEname( ));
		}
	}
}

mengkompilasi dan menjalankan program di atas, Anda akan menghasilkan output berikut di panel konsol Eclipse IDE.

Employee ID :1201	 Employee Name :Gopal
Employee ID :1206	 Employee Name :Kiran
Employee ID :1205	 Employee Name :Krishna
Employee ID :1202	 Employee Name :Manisha
Employee ID :1203	 Employee Name :Masthanvali
Employee ID :1204	 Employee Name :Satish

Kueri Bernama

Anotasi @NamedQuery didefinisikan sebagai kueri dengan string kueri yang telah ditentukan sebelumnya yang tidak dapat diubah. Berbeda dengan kueri dinamis, kueri bernama dapat meningkatkan organisasi kode dengan memisahkan string kueri JPQL dari POJO. Ini juga meneruskan parameter kueri daripada menyematkan literal secara dinamis ke dalam string kueri dan karenanya menghasilkan kueri yang lebih efisien.

Pertama-tama, tambahkan anotasi @NamedQuery ke kelas entitas Karyawan bernama Employee.java dibawah com.tutorialspoint.eclipselink.entity paket 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.NamedQuery;
import javax.persistence.Table;

@Entity
@Table
@NamedQuery(query = "Select e from Employee e where e.eid = :id", 
		name = "find employee by id")
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 + "]";
	}
}

Buat kelas bernama NamedQueries.java dibawah com.tutorialspoint.eclipselink.service paket sebagai berikut:

package com.tutorialspoint.eclipselink.service;

import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
import com.tutorialspoint.eclipselink.entity.Employee;

public class NamedQueries 
{
	public static void main( String[ ] args ) 
	{
		EntityManagerFactory emfactory = Persistence.
			createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
			createEntityManager();
		Query query = entitymanager.createNamedQuery(
			"find employee by id");
		query.setParameter("id", 1204);
		List<Employee> list = query.getResultList( );
		for( Employee e:list )
		{
			System.out.print("Employee ID :"+e.getEid( ));
			System.out.println("\t Employee Name :"+e.getEname( ));
		}
	}
}

Setelah mengompilasi dan menjalankan program di atas, Anda akan mendapatkan keluaran berikut di panel konsol Eclipse IDE.

Employee ID :1204	 Employee Name :Satish

Setelah menambahkan semua kelas di atas, hierarki paket terlihat sebagai berikut:

Eager and Lazy Fetching

Konsep paling penting dari JPA adalah membuat salinan duplikat dari database di memori cache. Saat bertransaksi dengan database, JPA pertama kali membuat kumpulan data duplikat dan hanya jika dilakukan menggunakan manajer entitas, perubahan diterapkan ke database.

Ada dua cara untuk mengambil record dari database.

Ambil dengan bersemangat

Dalam pengambilan yang bersemangat, objek turunan terkait diunggah secara otomatis saat mengambil rekaman tertentu.

Pengambilan malas

Dalam pengambilan lambat, objek terkait tidak diunggah secara otomatis kecuali Anda memintanya secara khusus. Pertama-tama, ia memeriksa ketersediaan objek terkait dan memberi tahu. Nanti, jika Anda memanggil salah satu metode pengambil entitas itu, maka itu mengambil semua catatan.

Pengambilan lambat dimungkinkan saat Anda mencoba mengambil rekaman untuk pertama kalinya. Dengan begitu, salinan dari seluruh catatan sudah disimpan di memori cache. Dari segi performa, pengambilan lambat lebih disukai.

JPA adalah perpustakaan yang dirilis dengan spesifikasi Java. Oleh karena itu, ini mendukung semua konsep berorientasi objek untuk persistensi entitas. Sampai sekarang, kita sudah 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 setiap bahasa berorientasi objek, oleh karena itu kita dapat menggunakan hubungan atau strategi pewarisan antar entitas. JPA mendukung tiga jenis strategi warisan: SINGLE_TABLE, JOINED_TABLE, dan TABLE_PER_CONCRETE_CLASS.

Mari kita lihat contohnya. Diagram berikut menunjukkan tiga kelas, yaitu. Staff, TeachingStaff, dan NonTeachingStaff, dan hubungan mereka.

Dalam diagram di atas, Staff adalah sebuah entitas, sedangkan TeachingStaff dan NonTeachingStaff adalah sub-entitas dari Staff. Di sini kita akan menggunakan contoh di atas untuk mendemonstrasikan 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 dari Staff. Sesuai dengan konsep pewarisan, sub-kelas mewarisi properti kelas supernya. Oleh karena itu sid dan sname adalah bidang yang dimiliki oleh TeachingStaff dan NonTeachingStaff. Buat proyek JPA. Semua modul dari proyek ini adalah 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 nilainya 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

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 menyusun dan menjalankan 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 field dari ketiga kelas 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 di bawah ini.

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.javadi bawah paket yang diberikan untuk menyimpan bidang kelas Staff, TeachingStaff, dan NonTeachingStaff. Kemudian 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 menyusun dan menjalankan program di atas, Anda akan mendapatkan notifikasi di panel konsol Eclipse IDE. Untuk keluaran, periksa meja kerja MySQL.

Di sini tiga tabel dibuat dan hasil dari staff tabel ditampilkan dalam format tabel.

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

Hasil dari TeachingStaff 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 ditampilkan sebagai berikut:

Sid Keahlian daerah
3 Akun
4 Admin Kantor

Terakhir, ketiga tabel dibuat menggunakan bidang masing-masing dan bidang SID digunakan bersama oleh ketiga tabel tersebut. Di tabel Staf, SID adalah kunci utama. Di dua 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 nilai null. Nilai bidang tabel Staff harus dibagi oleh tabel TeachingStaff dan NonTeachingStaff.

Mari kita perhatikan contoh yang sama seperti di atas.

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 menyusun dan menjalankan program di atas, Anda akan mendapatkan notifikasi di panel konsol Eclipse IDE. Untuk keluaran, periksa meja kerja MySQL.

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

Hasil dari TeachingStaff 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 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.

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 antara entitas ada di mana satu entitas (kolom atau kumpulan kolom) direferensikan dengan entitas lain (kolom atau kumpulan kolom) yang berisi nilai unik. Dalam database relasional, relasi ini diterapkan dengan menggunakan kunci asing / kunci primer antar tabel.

Mari kita pertimbangkan contoh hubungan antara entitas Karyawan dan Departemen. Secara searah, misalnya, dari Karyawan ke Departemen, hubungan Banyak-ke-Satu dapat diterapkan. Itu berarti setiap catatan karyawan berisi satu id departemen, yang seharusnya menjadi kunci utama dalam tabel Departemen. Di sini, di tabel Karyawan, id Departemen adalah kunci asing.

Diagram berikut memperlihatkan relasi Banyak-Ke-Satu antara dua tabel.

Buat proyek JPA dalam IDE eclipse bernama JPA_Eclipselink_MTO. Semua modul proyek ini dibahas di bawah ini.

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 menyusun dan menjalankan 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 akan ditampilkan sebagai berikut:

Select * from department
Indo Nama
101 Pengembangan

Teruskan kueri berikut di antarmuka MySQL dan hasil Employee tabel akan ditampilkan sebagai berikut.

Select * from employee
Idul Fitri Deg Ename Gaji Department_Id
102 Penulis teknis Satish 45000 101
103 Penulis teknis Krishna 45000 101
104 Penulis teknis Masthanwali 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 direferensikan 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 bisa ditautkan ke satu atau beberapa baris di Tabel B.

Mari kita perhatikan contoh di atas. Misalkan tabel Pegawai dan Departemen pada contoh di atas dihubungkan secara searah terbalik, maka relasinya menjadi relasi One-To-Many. Buat proyek JPA dalam IDE eclipse bernamaJPA_Eclipselink_OTM. Semua modul proyek ini dibahas di bawah ini.

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

File persistence.xml adalah 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. Lewati query berikut di antarmuka MySQL dan hasil tabel department_employee akan ditampilkan sebagai berikut:

Select * from department_Id;
Department_ID Employee_Eid
254 251
254 252
254 253

Di tabel di atas, deparment_id dan employee_id adalah kunci asing (bidang referensi) dari tabel departemen dan karyawan.

Lewati query berikut di antarmuka MySQL dan hasil dari tabel departemen akan ditampilkan dalam format tabel sebagai berikut.

Select * from department;
Indo Nama
254 Pengembangan

Lewati kueri berikut di antarmuka MySQL dan hasil tabel karyawan akan ditampilkan sebagai berikut:

Select * from employee;
Idul Fitri Deg Ename Gaji
251 Penulis teknis Satish 45000
252 Penulis teknis Krishna 45000
253 Penulis teknis Masthanwali 50000

@OneToOne Relation

Dalam hubungan satu-ke-satu, satu item hanya dapat ditautkan ke 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 dibahas di bawah ini.

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

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.

Pada contoh di atas, dua tabel dibuat. Lewati query berikut di antarmuka MySQL dan hasil dari tabel departemen akan ditampilkan sebagai berikut:

Select * from department
Indo Nama
301 Pengembangan

Teruskan kueri berikut di antarmuka MySQL dan hasil employee tabel akan ditampilkan sebagai berikut:

Select * from employee
Idul Fitri Deg Ename Gaji Department_id
302 Penulis teknis 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 perhatikan contoh relasi antara dua entitas: Class dan Teacher. Secara dua arah, baik 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 dibahas di bawah ini.

Membuat Entitas

Buat entitas dengan mengikuti skema yang ditunjukkan pada diagram di atas. 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 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

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

Dalam proyek contoh ini, tiga tabel dibuat. Lewati query berikut di antarmuka MySQL dan hasil tabel teacher_clas akan ditampilkan sebagai berikut:

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

Di tabel di atas teacher_tid adalah kunci asing dari tabel guru, dan classet_cidadalah 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 akan ditampilkan sebagai berikut:

Select * from teacher
Tid Subyek Tname
354 Jawa Satish
355 Adv Java Krishna
356 DB2 Masthanvali

Teruskan kueri berikut di antarmuka MySQL dan hasil clas tabel akan ditampilkan sebagai berikut:

Select * from clas
Cid Cname
351 1st
352 2nd
353 3

Kriteria adalah API standar yang digunakan untuk menentukan kueri untuk entitas. Ini adalah cara alternatif untuk mendefinisikan kueri JPQL. Kueri ini tipe-aman, portabel, dan mudah dimodifikasi dengan mengubah sintaks. Mirip dengan JPQL, ini mengikuti skema abstrak (skema yang mudah diedit) dan objek yang disematkan. API metadata dicampur dengan API kriteria untuk membuat model entitas persisten untuk kueri kriteria.

Keuntungan utama dari Criteria API adalah kesalahan dapat dideteksi lebih awal selama waktu kompilasi. Kueri JPQL berbasis string dan kueri berbasis kriteria JPA memiliki kinerja dan efisiensi yang sama.

Sejarah API kriteria

Kriteria ini termasuk ke dalam semua versi JPA sehingga setiap langkah kriteria diberitahukan dalam spesifikasi JPA.

  • Di JPA 2.0, API kueri kriteria, standardisasi kueri dikembangkan.
  • Di JPA 2.1, Pembaruan dan penghapusan kriteria (pembaruan dan penghapusan massal) disertakan.

Struktur Query Kriteria

Kriteria dan JPQL terkait erat dan diizinkan untuk mendesain menggunakan operator serupa dalam kueri mereka. Itu mengikutijavax.persistence.criteriapaket untuk mendesain kueri. Struktur kueri berarti kueri kriteria sintaksis.

Kueri kriteria sederhana berikut mengembalikan semua contoh kelas entitas di sumber data.

EntityManager em = ...;
CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Entity class> cq = cb.createQuery(Entity.class);
Root<Entity> from = cq.from(Entity.class);
cq.select(Entity);
TypedQuery<Entity> q = em.createQuery(cq);
List<Entity> allitems = q.getResultList();

Kueri mendemonstrasikan langkah-langkah dasar untuk membuat kriteria.

  • EntityManager instance digunakan untuk membuat objek CriteriaBuilder.

  • CriteriaQueryinstance digunakan untuk membuat objek kueri. Atribut objek kueri ini akan dimodifikasi dengan detail kueri.

  • CriteriaQuery.form metode dipanggil untuk mengatur root kueri.

  • CriteriaQuery.select dipanggil untuk menyetel jenis daftar hasil.

  • TypedQuery<T> instance digunakan untuk menyiapkan kueri untuk dieksekusi dan menentukan jenis hasil kueri.

  • getResultListmetode pada objek TypedQuery <T> untuk mengeksekusi kueri. Kueri ini mengembalikan kumpulan entitas, hasilnya disimpan dalam Daftar.

Contoh API kriteria

Mari kita perhatikan contoh database karyawan. Mari kita asumsikan tabel jpadb.employee berisi catatan berikut:

Eid	 Ename          Salary	Deg
401	 Gopal	        40000	Technical Manager
402	 Manisha	    40000	Proof reader
403	 Masthanvali    35000	Technical Writer
404  Satish	        30000	Technical writer
405	 Krishna	    30000	Technical Writer
406	 Kiran	        35000	Proof reader

Buat Proyek JPA di IDE eclipse bernama JPA_Eclipselink_Criteria. Semua modul proyek ini dibahas di bawah ini:

Membuat Entitas

Buat paket bernama com.tutorialspoint.eclipselink.entity dibawah ‘src’

Buat kelas bernama Employee.javadi bawah paket yang diberikan. Entitas Karyawan 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 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 + "]";
	}
}

Persistence.xml

File Persistence.xml adalah 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>
		<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 kueri Kriteria menggunakan inisialisasi API MetaData. Buat paket bernama‘com.tutorialspoint.eclipselink.service’. Kelas bernamaCriteriaAPI.javadibuat di bawah paket yang diberikan. Kelas DAO ditampilkan sebagai berikut:

package com.tutorialspoint.eclipselink.service;

import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.TypedQuery;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;
import com.tutorialspoint.eclipselink.entity.Employee;

public class CriteriaApi 
{
	public static void main(String[] args) 
	{
		EntityManagerFactory emfactory = Persistence.
				createEntityManagerFactory( "Eclipselink_JPA" );
		EntityManager entitymanager = emfactory.
				createEntityManager( );
		CriteriaBuilder criteriaBuilder = entitymanager
				.getCriteriaBuilder();
		CriteriaQuery<Object> criteriaQuery = criteriaBuilder
				.createQuery();
		Root<Employee> from = criteriaQuery.from(Employee.class);
		
		//select all records
        System.out.println(“Select all records”);
		CriteriaQuery<Object> select =criteriaQuery.select(from);
		TypedQuery<Object> typedQuery = entitymanager
				.createQuery(select);
		List<Object> resultlist= typedQuery.getResultList();
		
		for(Object o:resultlist)
		{
			Employee e=(Employee)o;
			System.out.println("EID : "+e.getEid()
					+" Ename : "+e.getEname());
		}
		
		//Ordering the records 
        System.out.println(“Select all records by follow ordering”);
		CriteriaQuery<Object> select1 = criteriaQuery.select(from);
        select1.orderBy(criteriaBuilder.asc(from.get("ename")));
        TypedQuery<Object> typedQuery1 = entitymanager
        		.createQuery(select);
        List<Object> resultlist1= typedQuery1.getResultList();
		
		for(Object o:resultlist1)
		{
			Employee e=(Employee)o;
			System.out.println("EID : "+e.getEid()
					+" Ename : "+e.getEname());
		}
		
		entitymanager.close( );
		emfactory.close( );
	}
}

Setelah menyusun dan menjalankan program di atas, Anda akan mendapatkan output berikut di panel konsol Eclipse IDE.

Select All records
EID : 401 Ename : Gopal
EID : 402 Ename : Manisha
EID : 403 Ename : Masthanvali
EID : 404 Ename : Satish
EID : 405 Ename : Krishna
EID : 406 Ename : Kiran
Select All records by follow Ordering
EID : 401 Ename : Gopal
EID : 406 Ename : Kiran
EID : 405 Ename : Krishna
EID : 402 Ename : Manisha
EID : 403 Ename : Masthanvali
EID : 404 Ename : Satish