Mengapa Sesi Terbuka dalam Paparan dalam Hibernate ialah Amalan Buruk
Sesi Terbuka dalam Paparan (OSIV) ialah corak dalam Hibernate yang melibatkan penyimpanan sesi dibuka sepanjang permintaan HTTP. Walaupun ini mungkin kelihatan bermanfaat untuk mengelakkan LazyLoadExceptions, ia memperkenalkan banyak kelemahan:
Isu Perspektif Pangkalan Data:
-
Mod autokomit: Memandangkan transaksi dilakukan oleh lapisan perkhidmatan tetapi tidak secara eksplisit dalam OSIV, pangkalan data seterusnya pernyataan daripada pemaparan UI dilaksanakan dalam mod autokomit. Ini membebankan pelayan pangkalan data dengan memerlukan log transaksi yang kerap disiram.
-
Sumber pernyataan bercampur: OSIV membenarkan pernyataan dijana oleh kedua-dua lapisan perkhidmatan dan proses pemaparan UI, menjadikannya sukar untuk diuji interaksi pangkalan data merentas lapisan.
Kerumitan dan Skalabilitas Kod Isu:
-
Keupayaan UI terhad: OSIV mengehadkan lapisan UI untuk menavigasi persatuan, yang berpotensi mencetuskan masalah pertanyaan N 1.
-
Sambungan menahan: OSIV boleh menahan sambungan pangkalan data sepanjang pemaparan UI, meningkatkan sambungan masa pajakan dan mengurangkan pemprosesan transaksi.
Pertimbangan Spring Boot:
Dalam Spring Boot, OSIV didayakan secara lalai. Adalah disyorkan untuk melumpuhkannya dengan menetapkan spring.jpa.open-in-view=false dalam konfigurasi aplikasi.
Strategi Alternatif untuk Mengelakkan LazyLoadExceptions:
Sebaliknya OSIV, pertimbangkan:
-
Bersemangat perhubungan: Bersungguh-sungguh mengambil perkaitan yang diperlukan oleh lapisan paparan, memastikan ia dimuatkan apabila entiti diambil.
-
Pengambilan eksplisit dalam lapisan perkhidmatan: Gunakan kaedah seperti fetch() untuk secara eksplisit mengambil persatuan sebelum memberikan paparan.
-
Unjuran: Gunakan unjuran untuk mendapatkan hanya data yang diperlukan oleh lapisan paparan, mengelakkan pengamulaan malas yang tidak perlu.
-
API Kriteria: Gunakan API Kriteria untuk menyesuaikan pertanyaan dan pengambilan yang tidak sabar-sabar persatuan.
-
Graf entiti: Tentukan graf entiti untuk mengoptimumkan perolehan semula persatuan berdasarkan kes penggunaan tertentu.
Atas ialah kandungan terperinci Adakah Open Session in View (OSIV) dalam Hibernate adalah Amalan Buruk dan Apakah Alternatifnya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!
Kenyataan:Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn