Langsung ke konten utama

Composite Primary Keys in JPA

Description

Composite Primary Key adalah kombinasi dari dua atau lebih kolom dari table untuk dijadikan primary key atau acuan identitas data.

Di JPA kita bisa membuat Composite Primary Key dengan dua cara yaitu menggunakan anotasi @IdClass dan @EmbeddedId.

Untuk membuat Composite Primary Key, kita harus ikuti aturan berikut: 

1. Class Composite Primary Key harus public

2. Harus memiliki Konstruktor kosong/tanpa parameter(no-arg constructor)

3. Class harus implementasi Serializable


How To

1. Menggunakan anotasi @IdClass

Disini kita contohkan kita memiliki table Account yang memiliki kolom, accountNumber dan accountType yang mana dua column tersebut akan kita gunakan sebagai Composite Primary Key di JPA kita.

Pertama kita buat class AccountId sebagai primary key nya.

public class AccountId implements Serializable { private String accountNumber; private String accountType; // default constructor public AccountId(String accountNumber, String accountType) { this.accountNumber = accountNumber; this.accountType = accountType; } // equals() and hashCode() }

disini kita gunakan class AccountId dan kita deklarasikan accountNumber dan accountType menggunakan anotasi @Id

@Entity @IdClass(AccountId.class) public class Account { @Id private String accountNumber; @Id private String accountType; // other fields, getters and setters }

2. Menggunakan anotasi @EmbeddedId

@EmbeddedId adalah alternative dari @IdClass, disini kita contohkan kita memiliki table Book yang dia memiliki kolom title dan language.

pertama kita buat class BookId sebagai field primary key nya.

@Embeddable public class BookId implements Serializable { private String title; private String language; // default constructor public BookId(String title, String language) { this.title = title; this.language = language; } // getters, equals() and hashCode() methods }

setelah kita buat kelas BookId kita gunakan di entitynya dengan menggunakan anotasi @EmbeddedId seperti dibawah.

@Entity public class Book { @EmbeddedId private BookId bookId; // constructors, other fields, getters and setters }


@EmbeddedId vs @IdClass

perbedaannya adalah @IdClass lebih simple dari cara query JPQL nya seperti dibawah ini.

query menggunakan @IdClass

SELECT account.accountNumber FROM Account account

query menggunakan @EmbeddedId

SELECT book.bookId.title FROM Book book


Source: https://www.baeldung.com/jpa-composite-primary-keys

Komentar

Postingan populer dari blog ini

whois

  Pengertian:  whois adalah tools yang digunakan untuk melihat informasi mengenai kepemilikan domain dan website. ICANN meregulasikan domain name dan kepemelikian, tapi record listnya di adakan di semua company dikenal sebagai registrasi.  jadi orang bisa query list of records, dan register akan menghandle request anda dan mengirim detail dari whois record yang sesuai. How to Install whois :  sudo apt-get install whois How to use:  whois cnn.com dan hasilnya akan seperti ini. Domain Name: CNN.COM Registry Domain ID: 3269879_DOMAIN_COM-VRSN Registrar WHOIS Server: whois.corporatedomains.com Registrar URL: http://www.cscglobal.com/global/web/csc/digital-brand-services.html Updated Date: 2018-04-10T16:43:38Z Creation Date: 1993-09-22T04:00:00Z Registry Expiry Date: 2026-09-21T04:00:00Z Registrar: CSC Corporate Domains, Inc. Registrar IANA ID: 299 Registrar Abuse Contact Email: domainabuse@cscglobal.com Registrar Abuse Contact Phone: 8887802723 Domain Status: clien...

Membuat export dan import Excel di spring boot

Membuat export dan import Excel  di spring boot           Adakalanya seorang developer diminta untuk membuat fitur export dan import berbentuk excel dan sebenarnya java sudah menyediakan suatu liblary yang memudahkan kita untuk bekerja dengan MS-Office yaitu Apache POI. Disini saya akan menggunakan Apache POI untuk membaca dan menulis Excel. Catatan : Disini saya sarankan untuk belajar Apache POI Excel terlebih dahulu agar anda mengerti kode yang saya buat di bawah ini. Bahan : -  IntelliJ IDEA -  PostgreSQL -  Maven -  Java 8 Jika sudah tersedia bahan - bahan di atas langsung saja kunjungi situs ini Tambahkan dependency Apache POI di pom.xml seperti di bawah ini. <?xml version="1.0" encoding="UTF-8"?> <project xmlns= "http://maven.apache.org/POM/4.0.0" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation= "http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0...

Spring Boot CRUD Thymeleaf-Pagination + Bootstrap Dynamic Modals

Spring Boot CRUD Thymeeaf-Pagination + Bootstrap Dynamic Modals                Sebelumnya saya sudah sharing bagaimana cara membuat Spring Boot CRUD sederhana di artikel sebelumnya yang blum lihat silahkan lihat disini . Sekarang saya akan membuat Spring Boot CRUD lagi ala pagination dan Dynamic Modals dengan bootstrap. Bahan : - IntelliJ IDEA - PostgreSQL - Maven - JDK1.8 Jika bahan nya sudah tersedia agan bisa kunjungi situs resmi spring nya https://start.spring.io/  buat seperti ini lalu download dan exract. Buat database yang bernama "springbootcrud2" disini saya menggunakan pgadmin4. Buka intelliJ atau IDE kesayangan kalian buka file application.properties di dalam resources dan isikan ini untuk configurasi databasenya sesuai kan dengan database kalian lalu save. ## Spring DATASOURCE (DataSourceAutoConfiguration & DataSourceProperties) spring.datasource.url = jdbc:postgresql://loc...