MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

MongoDB CursorNotFound Грешка при collection.find() за няколкостотин малки записа

Можете да опитате тези 3 неща:

a) Задайте курсора към false

db.collection.find().noCursorTimeout();

Трябва да затворите курсора в даден момент с cursor.close();

б) Или намалете размера на пакета

db.inventory.find().batchSize(10);

c) Опитайте отново, когато курсорът изтече:

let processed = 0;
let updated = 0;

while(true) {
    const cursor = db.snapshots.find().sort({ _id: 1 }).skip(processed);

    try {
        while (cursor.hasNext()) {
            const doc = cursor.next();

            ++processed;

            if (doc.stream && doc.roundedDate && !doc.sid) {
                db.snapshots.update({
                    _id: doc._id
                }, { $set: {
                    sid: `${ doc.stream.valueOf() }-${ doc.roundedDate }`
                }});

                ++updated;
            } 
        }

        break; // Done processing all, exit outer loop
    } catch (err) {
        if (err.code !== 43) {
            // Something else than a timeout went wrong. Abort loop.

            throw err;
        }
    }
}


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. MongoDB Отдалечена връзка с php

  2. Подобрете структурата на агрегиране на MongoDB

  3. Персонализирано каскадиране в Spring Data MongoDB

  4. Използвайте lean в mongoose с обратно извикване

  5. Какъв е пътят към базата данни по подразбиране за MongoDB?