Rumah hujung hadapan web tutorial js Melancarkan MongoDB: Mengapa Penomboran Berasaskan Kursor Mengungguli Penomboran Berasaskan Offset Setiap Kali!

Melancarkan MongoDB: Mengapa Penomboran Berasaskan Kursor Mengungguli Penomboran Berasaskan Offset Setiap Kali!

Sep 04, 2024 pm 10:43 PM

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();
}

Image description

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 < 2000000; i++) {
      bulkOps.push({
        insertOne: {
          documentId: i,
          name: `Record-${i}`,
          value: Math.random() * 1000,
        },
      });

      // Execute every 10000 operations and reinitialize
      if (bulkOps.length === 10000) {
        await collection.bulkWrite(bulkOps);
        bulkOps = [];
      }
    }

    if (bulkOps.length > 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!

Kenyataan Laman Web ini
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

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Stock Market GPT

Stock Market GPT

Penyelidikan pelaburan dikuasakan AI untuk keputusan yang lebih bijak

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana anda memilih elemen dengan atribut data dalam JavaScript? Bagaimana anda memilih elemen dengan atribut data dalam JavaScript? Aug 30, 2025 am 01:57 AM

Anda boleh memilih elemen dengan atribut data dalam JavaScript melalui pemilih atribut CSS, dan gunakan document.QuerySelector () atau document.QuerySelectorAll () kaedah untuk mencapai matlamat ini. 1. Gunakan [data-attribute] untuk memilih elemen dengan atribut data yang ditentukan (sebarang nilai); 2. Gunakan [data-attribute = "nilai"] untuk memilih elemen yang nilai atributnya sesuai; 3. Akses atribut data melalui elemen.dataset, di mana data-us-id sepadan dengan dataset.userid (ganti

Pytest dan Selenium: Strategi pelaksanaan untuk ujian yang didorong oleh data dinamik Pytest dan Selenium: Strategi pelaksanaan untuk ujian yang didorong oleh data dinamik Aug 30, 2025 am 06:00 AM

Artikel ini bertujuan untuk menyelesaikan masalah yang @pytest.mark.parametrize decorator tidak dapat secara langsung mengendalikan data yang dijana pada runtime apabila menggunakan pytest dan selenium untuk ujian yang didorong data dinamik. Kami akan meneroka batasan pytest.mark.parametrize secara mendalam, dan memperkenalkan secara terperinci bagaimana untuk melaksanakan ujian parameter secara anggun berdasarkan pemerolehan data dinamik selenium melalui Pytest's PYTest_Generate_Tests Hook berfungsi untuk memastikan fleksibiliti dan kecekapan kes ujian.

Mengoptimumkan pengendalian acara lompat luaran dinamik di tetingkap pop timbul jQuery Mengoptimumkan pengendalian acara lompat luaran dinamik di tetingkap pop timbul jQuery Sep 01, 2025 am 11:48 AM

Artikel ini bertujuan untuk menyelesaikan masalah mengalihkan butang redirect pautan luaran dalam tetingkap pop-up jQuery menyebabkan kesilapan lompat. Apabila pengguna mengklik pelbagai pautan luaran dalam penggantian, butang lompat di pop timbul mungkin selalu menunjuk pada pautan pertama yang diklik. Penyelesaian teras adalah dengan menggunakan kaedah off ('klik') untuk membatalkan pengendali acara lama sebelum setiap mengikat peristiwa baru, memastikan bahawa tingkah laku lompat sentiasa menunjuk kepada URL sasaran terkini, dengan itu mencapai pengalihan pautan yang tepat dan terkawal.

Bina kaunter JavaScript berjalan dengan hari bekerja dan waktu bekerja Bina kaunter JavaScript berjalan dengan hari bekerja dan waktu bekerja Aug 31, 2025 am 06:30 AM

Artikel ini memperincikan bagaimana untuk membina kaunter masa yang tepat menggunakan JavaScript. Kaunter itu bertambah sekali seminit, tetapi hanya berjalan dalam hari kerja pratetap (Isnin hingga Jumaat) dan jam kerja (seperti 6 pagi hingga 8 malam). Ia boleh menjeda kenaikan semasa waktu tidak bekerja tetapi memaparkan nilai semasa dan menetapkan semula secara automatik pada hari pertama setiap bulan, memastikan ketepatan dan fleksibiliti logik pengiraan.

Bagaimana unsur -unsur DOM yang dibuat secara dinamik diakses dan dikendalikan oleh skrip yang dimuatkan Bagaimana unsur -unsur DOM yang dibuat secara dinamik diakses dan dikendalikan oleh skrip yang dimuatkan Aug 30, 2025 am 11:57 AM

Artikel ini menerangkan bagaimana skrip JavaScript dapat diakses dengan berkesan dan dimanipulasi apabila ia dimuatkan dan dilaksanakan sebelum penciptaan elemen DOM dalam pembangunan web. Kami akan memperkenalkan tiga strategi teras: secara langsung lulus rujukan elemen melalui nilai pulangan fungsi, menggunakan peristiwa tersuai untuk mencapai komunikasi antara modul, dan menggunakan MutationObserver untuk mendengar perubahan struktur DOM. Kaedah ini dapat membantu pemaju menyelesaikan cabaran antara masa pelaksanaan JavaScript dan pemuatan kandungan dinamik, memastikan skrip dapat mengendalikan unsur-unsur dengan betul, seperti menjadikannya drag-mampu.

Evolusi JavaScript: Lihat ES2023 dan seterusnya Evolusi JavaScript: Lihat ES2023 dan seterusnya Aug 29, 2025 am 12:18 AM

ES2023 telah memperkenalkan beberapa kemas kini praktikal, menandakan evolusi matang JavaScript. 1.Array.Prototype.Findlast () dan findLastIndex () kaedah menyokong carian dari akhir array, meningkatkan kecekapan log pemprosesan atau konfigurasi; 2.Hashbang Syntax (#!/Usr/bin/envnode) membolehkan fail JavaScript dilaksanakan secara langsung dalam sistem seperti UNIX; 3.Ror.Cause menyokong rantaian ralat, meningkatkan keupayaan debugging pengecualian; 4. Spesifikasi lemah dan set meningkatkan konsistensi enjin; Pada masa akan datang, penghias (Stage3), Rekod dan Tuples (

Cara mengemas kini sifat objek dalam javascript Cara mengemas kini sifat objek dalam javascript Sep 04, 2025 am 04:58 AM

USEDOTNOTATIONTOUPDATEPROPERIESSWITHITEDNAMES; 2.USEBEBRACKETNOTATIONFORDYNAMICORSPECIALCHARACTERPROPROPERYNAMES; 3.USEOBJECT.Assign () ToupdatemultiplePropertiesREbjects, NotingItmutatestheSheoriginessanEbjectiseStabjectiseStabjectSugoStaSteStrjectiseStabjectiseStabjectiseStabjectiseStern

Pemformatan nombor dalam JavaScript: Gunakan kaedah Tofixed () untuk mengekalkan tempat perpuluhan tetap Pemformatan nombor dalam JavaScript: Gunakan kaedah Tofixed () untuk mengekalkan tempat perpuluhan tetap Sep 16, 2025 am 11:57 AM

Tutorial ini menerangkan secara terperinci bagaimana untuk memformat nombor ke dalam rentetan dengan dua perpuluhan tetap dalam JavaScript, walaupun bilangan bulat boleh dipaparkan dalam bentuk "#.00". Kami akan memberi tumpuan kepada penggunaan number.Prototype.TOfixed (), termasuk sintaksnya, fungsi, kod sampel, dan mata utama yang perlu diperhatikan, seperti jenis pulangannya sentiasa menjadi rentetan.

See all articles