Cache peringkat pertama Mybatis dan penggunaan cache peringkat kedua: 1. Cache peringkat pertama ialah mekanisme cache yang didayakan oleh MyBatis secara lalai Ia akan menyemak dahulu sama ada hasil pertanyaan yang sama sudah wujud dalam cache peringkat pertama utas semasa. Jika ia wujud, ia akan dikembalikan terus ke data dan bukannya menghantar permintaan pertanyaan ke pangkalan data 2. Cache peringkat kedua ialah mekanisme caching berdasarkan ruang nama sudah wujud dalam cache peringkat kedua ruang nama semasa Jika ia wujud, ia akan terus mengembalikan data dalam cache dan bukannya menghantar permintaan pertanyaan ke pangkalan data.
MyBatis ialah rangka kerja lapisan kegigihan sumber terbuka yang menyediakan cara untuk memetakan objek Java kepada operasi pangkalan data. Dalam MyBatis, cache tahap pertama dan cache tahap kedua ialah dua tahap mekanisme caching yang berbeza, kedua-duanya boleh digunakan untuk meningkatkan prestasi.
Cache peringkat pertama ialah mekanisme caching yang didayakan oleh MyBatis secara lalai Ia adalah berasaskan thread, yang bermaksud setiap thread mempunyai cache peringkat pertamanya sendiri. Mekanisme kerja cache peringkat pertama ialah apabila menjalankan operasi pertanyaan, ia akan terlebih dahulu menyemak sama ada hasil pertanyaan yang sama sudah wujud dalam cache peringkat pertama utas semasa Jika ia wujud, ia akan mengembalikan data secara langsung dalam cache tanpa menghantar permintaan pertanyaan ke pangkalan data. Ini boleh mengurangkan bilangan akses pangkalan data dan meningkatkan prestasi pertanyaan.
Skop berkesan cache peringkat pertama adalah dalam SqlSession yang sama Apabila SqlSession ditutup atau sebarang operasi pengubahsuaian (masukkan, kemas kini, padam) dilakukan, cache peringkat pertama akan dikosongkan. Oleh itu, cache peringkat pertama sesuai untuk senario di mana data yang sama disoal beberapa kali dalam permintaan atau transaksi yang sama Untuk data yang kerap berubah atau berbilang permintaan serentak, kesan cache peringkat pertama mungkin tidak jelas.
Cache peringkat kedua ialah mekanisme caching berasaskan ruang nama yang boleh digunakan merentasi berbilang SqlSession. Mekanisme kerja cache peringkat kedua ialah apabila menjalankan operasi pertanyaan, ia akan terlebih dahulu menyemak sama ada hasil pertanyaan yang sama sudah wujud dalam cache peringkat kedua ruang nama semasa Jika ia wujud, data dalam cache akan menjadi terus dikembalikan tanpa menghantar permintaan pertanyaan ke pangkalan data. Ini boleh mengurangkan bilangan akses pangkalan data dan meningkatkan prestasi pertanyaan.
Skop berkesan cache peringkat kedua adalah dalam ruang nama yang sama Apabila sebarang operasi pengubahsuaian dibuat pada SqlSession di dalam ruang nama, cache peringkat kedua akan dikosongkan. Oleh itu, cache peringkat kedua sesuai untuk senario di mana data yang sama dikongsi antara berbilang SqlSession Untuk data yang kerap berubah atau berbilang permintaan serentak, kesan cache peringkat kedua mungkin tidak jelas.
Dalam MyBatis, cache tahap pertama dan cache tahap kedua adalah bebas antara satu sama lain, dan ia boleh digunakan pada masa yang sama atau secara berasingan. Cache peringkat pertama didayakan secara lalai dan tidak memerlukan konfigurasi, manakala cache peringkat kedua perlu dikonfigurasikan dalam fail konfigurasi MyBatis.
Untuk mengkonfigurasi cache tahap kedua, anda perlu menambah konfigurasi berikut pada fail konfigurasi Mapper:
Ini menghidupkan cache tahap kedua lalai, yang menggunakan PerpetualCache sebagai kelas pelaksanaan cache. Jika anda perlu menggunakan kelas pelaksanaan cache lain, anda boleh menyesuaikan kelas pelaksanaan dan menentukannya dalam fail konfigurasi.
Perlu diingatkan bahawa kitaran hayat cache peringkat kedua adalah sama dengan kitaran hayat aplikasi, iaitu, ia dicipta apabila aplikasi bermula dan dimusnahkan apabila aplikasi ditutup. Oleh itu, jika anda menggunakan MyBatis dalam persekitaran yang diedarkan, anda perlu mempertimbangkan penyegerakan cache dan mekanisme kemas kini untuk mengelakkan ketidakkonsistenan data.
Ringkasan
Cache tahap 1 dan cache tahap 2 ialah kedua-dua mekanisme caching yang digunakan untuk meningkatkan prestasi pertanyaan. Cache peringkat pertama adalah berdasarkan urutan dan sesuai untuk senario di mana data yang sama disoal beberapa kali dalam permintaan atau transaksi yang sama manakala cache peringkat kedua adalah berdasarkan ruang nama dan sesuai untuk senario di mana data yang sama dikongsi; antara berbilang SqlSession. Bergantung pada senario dan keperluan aplikasi tertentu, anda boleh memilih untuk menggunakan cache peringkat pertama, cache peringkat kedua atau kedua-duanya pada masa yang sama.
Atas ialah kandungan terperinci Penjelasan terperinci tentang penggunaan cache peringkat pertama mybatis dan cache peringkat kedua. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!