


Penomboran ialah bahagian penting dalam mana-mana operasi pangkalan data apabila berurusan dengan set data yang besar. Ia membolehkan anda membahagikan data kepada bahagian yang boleh diurus, menjadikannya lebih mudah untuk menyemak imbas, memproses dan memaparkan. MongoDB menyediakan dua kaedah penomboran biasa: berasaskan offset dan berasaskan kursor. Walaupun kedua-dua kaedah mempunyai tujuan yang sama, ia berbeza dengan ketara dalam prestasi dan kebolehgunaan, terutamanya apabila set data berkembang.
Mari kita menyelami dua pendekatan dan lihat sebab penomboran berasaskan kursor sering mengatasi prestasi penomboran berasaskan offset.
1. Penomboran Berasaskan Offset
Penomboran berasaskan offset adalah mudah. Ia mendapatkan semula bilangan rekod tertentu bermula daripada offset yang diberikan. Sebagai contoh, halaman pertama mungkin mendapatkan semula rekod 0-9, halaman kedua mendapatkan semula rekod 10-19 dan seterusnya.
Walau bagaimanapun, kaedah ini mempunyai kelemahan yang ketara: apabila anda beralih ke halaman yang lebih tinggi, pertanyaan menjadi lebih perlahan. Ini kerana pangkalan data perlu melangkau rekod dari halaman sebelumnya, yang melibatkan pengimbasan melaluinya.
Berikut ialah kod untuk penomboran berasaskan offset:
async function offset_based_pagination(params) { const { page = 5, limit = 100 } = params; const skip = (page - 1) * limit; const results = await collection.find({}).skip(skip).limit(limit).toArray(); console.log(`Offset-based pagination (Page ${page}):`, results.length, "page", page, "skip", skip, "limit", limit); }
2. Penomboran Berasaskan Kursor
Penomboran berasaskan kursor, juga dikenali sebagai penomboran set kekunci, bergantung pada pengecam unik (cth., ID atau cap masa) untuk menomborkan melalui rekod. Daripada melangkau bilangan rekod tertentu, ia menggunakan rekod yang diambil terakhir sebagai titik rujukan untuk mengambil set seterusnya.
Pendekatan ini lebih cekap kerana ia mengelakkan keperluan untuk mengimbas rekod sebelum halaman semasa. Akibatnya, masa pertanyaan kekal konsisten, tidak kira sejauh mana ke dalam set data yang anda gunakan.
Berikut ialah kod untuk penomboran berasaskan kursor:
async function cursor_based_pagination(params) { const { lastDocumentId, limit = 100 } = params; const query = lastDocumentId ? { documentId: { $gt: lastDocumentId } } : {}; const results = await collection .find(query) .sort({ documentId: 1 }) .limit(limit) .toArray(); console.log("Cursor-based pagination:", results.length); }
Dalam contoh ini, lastDocumentId ialah ID dokumen terakhir dari halaman sebelumnya. Apabila membuat pertanyaan untuk halaman seterusnya, pangkalan data mengambil dokumen dengan ID yang lebih besar daripada nilai ini, memastikan peralihan yang lancar ke set rekod seterusnya.
3. Perbandingan Prestasi
Mari kita lihat prestasi kedua-dua kaedah ini dengan set data yang besar.
async function testMongoDB() { console.time("MongoDB Insert Time:"); await insertMongoDBRecords(); console.timeEnd("MongoDB Insert Time:"); // Create an index on the documentId field await collection.createIndex({ documentId: 1 }); console.log("Index created on documentId field"); console.time("Offset-based pagination Time:"); await offset_based_pagination({ page: 2, limit: 250000 }); console.timeEnd("Offset-based pagination Time:"); console.time("Cursor-based pagination Time:"); await cursor_based_pagination({ lastDocumentId: 170000, limit: 250000 }); console.timeEnd("Cursor-based pagination Time:"); await client.close(); }
Dalam ujian prestasi, anda akan mendapati bahawa penomboran berasaskan offset mengambil masa lebih lama apabila nombor halaman meningkat, manakala kursor -based penomboran kekal konsisten, menjadikannya pilihan yang lebih baik untuk set data besar. Contoh ini juga menunjukkan kuasa pengindeksan juga. Cuba alih keluar indeks & kemudian lihat hasilnya juga!
Mengapa Pengindeksan Penting
Tanpa indeks, MongoDB perlu melakukan imbasan koleksi, yang bermaksud ia perlu melihat setiap dokumen dalam koleksi untuk mencari data yang berkaitan. Ini tidak cekap, terutamanya apabila set data anda berkembang. Indeks membolehkan MongoDB mencari dokumen yang sepadan dengan keadaan pertanyaan anda dengan cekap, mempercepatkan prestasi pertanyaan dengan ketara.
Dalam konteks penomboran berasaskan kursor, indeks memastikan bahawa pengambilan set dokumen seterusnya (berdasarkan documentId) adalah pantas dan tidak merendahkan prestasi apabila lebih banyak dokumen ditambahkan pada koleksi.
Kesimpulan
Walaupun penomboran berasaskan offset mudah dilaksanakan, ia boleh menjadi tidak cekap dengan set data yang besar kerana keperluan untuk mengimbas melalui rekod. Penomboran berasaskan kursor, sebaliknya, menyediakan penyelesaian yang lebih berskala, memastikan prestasi konsisten tanpa mengira saiz set data. Jika anda bekerja dengan koleksi besar dalam MongoDB, adalah wajar mempertimbangkan penomboran berasaskan kursor untuk pengalaman yang lebih lancar dan pantas.
Berikut ialah index.js lengkap untuk anda jalankan secara setempat:
const { MongoClient } = require("mongodb"); const uri = "mongodb://localhost:27017"; const client = new MongoClient(uri); client.connect(); const db = client.db("testdb"); const collection = db.collection("testCollection"); async function insertMongoDBRecords() { try { let bulkOps = []; for (let i = 0; i 0) { await collection.bulkWrite(bulkOps); console.log("? Inserted records till now -> ", bulkOps.length); } console.log("MongoDB Insertion Completed"); } catch (err) { console.error("Error in inserting records", err); } } async function offset_based_pagination(params) { const { page = 5, limit = 100 } = params; const skip = (page - 1) * limit; const results = await collection.find({}).skip(skip).limit(limit).toArray(); console.log(`Offset-based pagination (Page ${page}):`, results.length, "page", page, "skip", skip, "limit", limit); } async function cursor_based_pagination(params) { const { lastDocumentId, limit = 100 } = params; const query = lastDocumentId ? { documentId: { $gt: lastDocumentId } } : {}; const results = await collection .find(query) .sort({ documentId: 1 }) .limit(limit) .toArray(); console.log("Cursor-based pagination:", results.length); } async function testMongoDB() { console.time("MongoDB Insert Time:"); await insertMongoDBRecords(); console.timeEnd("MongoDB Insert Time:"); // Create an index on the documentId field await collection.createIndex({ documentId: 1 }); console.log("Index created on documentId field"); console.time("Offset-based pagination Time:"); await offset_based_pagination({ page: 2, limit: 250000 }); console.timeEnd("Offset-based pagination Time:"); console.time("Cursor-based pagination Time:"); await cursor_based_pagination({ lastDocumentId: 170000, limit: 250000 }); console.timeEnd("Cursor-based pagination Time:"); await client.close(); } testMongoDB();
Atas ialah kandungan terperinci Melancarkan MongoDB: Mengapa Penomboran Berasaskan Kursor Mengungguli Penomboran Berasaskan Offset Setiap Kali!. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Penggunaan utama JavaScript dalam pembangunan web termasuk interaksi klien, pengesahan bentuk dan komunikasi tak segerak. 1) kemas kini kandungan dinamik dan interaksi pengguna melalui operasi DOM; 2) pengesahan pelanggan dijalankan sebelum pengguna mengemukakan data untuk meningkatkan pengalaman pengguna; 3) Komunikasi yang tidak bersesuaian dengan pelayan dicapai melalui teknologi Ajax.

Memahami bagaimana enjin JavaScript berfungsi secara dalaman adalah penting kepada pemaju kerana ia membantu menulis kod yang lebih cekap dan memahami kesesakan prestasi dan strategi pengoptimuman. 1) aliran kerja enjin termasuk tiga peringkat: parsing, penyusun dan pelaksanaan; 2) Semasa proses pelaksanaan, enjin akan melakukan pengoptimuman dinamik, seperti cache dalam talian dan kelas tersembunyi; 3) Amalan terbaik termasuk mengelakkan pembolehubah global, mengoptimumkan gelung, menggunakan const dan membiarkan, dan mengelakkan penggunaan penutupan yang berlebihan.

Python lebih sesuai untuk pemula, dengan lengkung pembelajaran yang lancar dan sintaks ringkas; JavaScript sesuai untuk pembangunan front-end, dengan lengkung pembelajaran yang curam dan sintaks yang fleksibel. 1. Sintaks Python adalah intuitif dan sesuai untuk sains data dan pembangunan back-end. 2. JavaScript adalah fleksibel dan digunakan secara meluas dalam pengaturcaraan depan dan pelayan.

Python dan JavaScript mempunyai kelebihan dan kekurangan mereka sendiri dari segi komuniti, perpustakaan dan sumber. 1) Komuniti Python mesra dan sesuai untuk pemula, tetapi sumber pembangunan depan tidak kaya dengan JavaScript. 2) Python berkuasa dalam bidang sains data dan perpustakaan pembelajaran mesin, sementara JavaScript lebih baik dalam perpustakaan pembangunan dan kerangka pembangunan depan. 3) Kedua -duanya mempunyai sumber pembelajaran yang kaya, tetapi Python sesuai untuk memulakan dengan dokumen rasmi, sementara JavaScript lebih baik dengan MDNWebDocs. Pilihan harus berdasarkan keperluan projek dan kepentingan peribadi.

Peralihan dari C/C ke JavaScript memerlukan menyesuaikan diri dengan menaip dinamik, pengumpulan sampah dan pengaturcaraan asynchronous. 1) C/C adalah bahasa yang ditaip secara statik yang memerlukan pengurusan memori manual, manakala JavaScript ditaip secara dinamik dan pengumpulan sampah diproses secara automatik. 2) C/C perlu dikumpulkan ke dalam kod mesin, manakala JavaScript adalah bahasa yang ditafsirkan. 3) JavaScript memperkenalkan konsep seperti penutupan, rantaian prototaip dan janji, yang meningkatkan keupayaan pengaturcaraan fleksibiliti dan asynchronous.

Enjin JavaScript yang berbeza mempunyai kesan yang berbeza apabila menguraikan dan melaksanakan kod JavaScript, kerana prinsip pelaksanaan dan strategi pengoptimuman setiap enjin berbeza. 1. Analisis leksikal: Menukar kod sumber ke dalam unit leksikal. 2. Analisis Tatabahasa: Menjana pokok sintaks abstrak. 3. Pengoptimuman dan Penyusunan: Menjana kod mesin melalui pengkompil JIT. 4. Jalankan: Jalankan kod mesin. Enjin V8 mengoptimumkan melalui kompilasi segera dan kelas tersembunyi, Spidermonkey menggunakan sistem kesimpulan jenis, menghasilkan prestasi prestasi yang berbeza pada kod yang sama.

Aplikasi JavaScript di dunia nyata termasuk pengaturcaraan sisi pelayan, pembangunan aplikasi mudah alih dan Internet of Things Control: 1. Pengaturcaraan sisi pelayan direalisasikan melalui node.js, sesuai untuk pemprosesan permintaan serentak yang tinggi. 2. Pembangunan aplikasi mudah alih dijalankan melalui reaktnatif dan menyokong penggunaan silang platform. 3. Digunakan untuk kawalan peranti IoT melalui Perpustakaan Johnny-Five, sesuai untuk interaksi perkakasan.

Saya membina aplikasi SaaS multi-penyewa berfungsi (aplikasi edTech) dengan alat teknologi harian anda dan anda boleh melakukan perkara yang sama. Pertama, apakah aplikasi SaaS multi-penyewa? Aplikasi SaaS Multi-penyewa membolehkan anda melayani beberapa pelanggan dari Sing


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

Dreamweaver CS6
Alat pembangunan web visual

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa