Hibernate - Sesi

Sesi digunakan untuk mendapatkan koneksi fisik dengan database. Objek Session ringan dan dirancang untuk dibuat instance-nya setiap kali diperlukan interaksi dengan database. Objek persisten disimpan dan diambil melalui objek Sesi.

Objek sesi tidak boleh dibuka untuk waktu yang lama karena biasanya tidak aman untuk thread dan harus dibuat serta dimusnahkan sesuai kebutuhan. Fungsi utama Sesi ini adalah menawarkan, membuat, membaca, dan menghapus operasi untuk instance kelas entitas yang dipetakan.

Contoh mungkin ada di salah satu dari tiga keadaan berikut pada titik waktu tertentu -

  • transient - Sebuah contoh baru dari kelas persisten, yang tidak terkait dengan Sesi dan tidak memiliki representasi dalam database dan tidak ada nilai pengenal yang dianggap sementara oleh Hibernate.

  • persistent- Anda dapat membuat instance sementara tetap ada dengan mengaitkannya dengan Sesi. Instance persisten memiliki representasi dalam database, nilai pengenal, dan terkait dengan Sesi.

  • detached - Setelah kami menutup Sesi Hibernasi, instance persisten akan menjadi instance yang terlepas.

Instance Sesi dapat dibuat serial jika kelas persistennya dapat diserialkan. Transaksi tipikal harus menggunakan idiom berikut -

Session session = factory.openSession();
Transaction tx = null;

try {
   tx = session.beginTransaction();
   // do some work
   ...
   tx.commit();
}

catch (Exception e) {
   if (tx!=null) tx.rollback();
   e.printStackTrace(); 
} finally {
   session.close();
}

Jika Sesi membuat pengecualian, transaksi harus dibatalkan dan sesi tersebut harus dibuang.

Metode Antarmuka Sesi

Ada beberapa metode yang disediakan oleh Sessionantarmuka, tapi saya akan membuat daftar beberapa metode penting saja, yang akan kita gunakan dalam tutorial ini. Anda dapat memeriksa dokumentasi Hibernate untuk daftar lengkap metode yang terkaitSession dan SessionFactory.

Sr.No. Metode & Deskripsi Sesi
1

Transaction beginTransaction()

Memulai unit kerja dan mengembalikan objek Transaksi terkait.

2

void cancelQuery()

Batalkan eksekusi kueri saat ini.

3

void clear()

Kosongkan sesi sepenuhnya.

4

Connection close()

Akhiri sesi dengan melepaskan koneksi JDBC dan bersihkan.

5

Criteria createCriteria(Class persistentClass)

Buat instance Kriteria baru, untuk kelas entitas tertentu, atau superclass dari kelas entitas.

6

Criteria createCriteria(String entityName)

Buat instance Kriteria baru, untuk nama entitas yang diberikan.

7

Serializable getIdentifier(Object object)

Kembalikan nilai pengenal dari entitas yang diberikan seperti yang terkait dengan sesi ini.

8

Query createFilter(Object collection, String queryString)

Buat instance baru dari Query untuk kumpulan dan filter string yang diberikan.

9

Query createQuery(String queryString)

Buat instance baru dari Query untuk string kueri HQL yang diberikan.

10

SQLQuery createSQLQuery(String queryString)

Buat instance baru SQLQuery untuk string kueri SQL yang diberikan.

11

void delete(Object object)

Hapus instance persisten dari datastore.

12

void delete(String entityName, Object object)

Hapus instance persisten dari datastore.

13

Session get(String entityName, Serializable id)

Kembalikan contoh persisten dari entitas bernama yang diberikan dengan pengenal yang diberikan, atau nol jika tidak ada contoh persisten seperti itu.

14

SessionFactory getSessionFactory()

Dapatkan pabrik sesi yang membuat sesi ini.

15

void refresh(Object object)

Baca ulang status instance yang diberikan dari database yang mendasarinya.

16

Transaction getTransaction()

Dapatkan contoh Transaksi yang terkait dengan sesi ini.

17

boolean isConnected()

Periksa apakah sesi saat ini terhubung.

18

boolean isDirty()

Apakah sesi ini berisi perubahan yang harus disinkronkan dengan database?

19

boolean isOpen()

Periksa apakah sesi masih terbuka.

20

Serializable save(Object object)

Pertahankan instance transien yang diberikan, pertama-tama tetapkan pengenal yang dihasilkan.

21

void saveOrUpdate(Object object)

Simpan (Object) atau perbarui (Object) instance yang diberikan.

22

void update(Object object)

Perbarui instance persisten dengan pengenal dari instance terpisah yang diberikan.

23

void update(String entityName, Object object)

Perbarui instance persisten dengan pengenal dari instance terpisah yang diberikan.