0

我正在使用 MongoDB 实现一个记录器数据库。上限集合将包含从网络上的多个来源收集的日志消息。因为我想$lte/$gte在之后进行查询,_id所以我需要一个_id作为单调函数增长的函数。

为了实现这一点,我实现了本文http://docs.mongodb.org/manual/tutorial/create-an-auto-incrementing-field/中描述的自动递增计数器

我的代码如下所示:

var mongo = require("mongodb");
var Promise = require('es6-promise').Promise;

function connectToDB(mongo, uri) {
    return new Promise(function(resolve, reject) {
        mongo.MongoClient.connect(uri, function (err, db) {
            if(err) reject(err);
            else resolve(db);
        });
    });
}

function getNextSequenceNumber(db, counterName) {
    return new Promise(function(resolve, reject) {
        db.collection("counters", function (err, collection) {
            if (err) reject(err);
            else {
                var criteria = { _id: counterName };
                var sort =  {$natural: 1};
                var update =  { $inc: { seq: 1 } };
                var options = {remove: false, new: true, upsert: true};
                collection.findAndModify(criteria, sort, update, options, function(err, res) {
                    if(err) reject(err);
                    else resolve(res.seq);
                });
            }
        });
    });
}

它工作得很好,但我读过默认情况下,MongoDB 中使用的数字字段实际上是浮点数。问题是我的数据库是一个有上限的日志条目集合,它将有很多条目。此外,由于这是一个上限集合,旧条目将被覆盖,但计数器将继续增长。将计数器作为浮点数,我不能保证系统会在几年后继续工作。我的问题是在这种特殊情况下如何强制 MongoDB 使用 64 位计数器。

请提供一些代码示例。

4

1 回答 1

2

MongoDB(或者更确切地说是 BSON)具有NumberLong类型,它是一个 64 位有符号整数。

在 Node.js 中,您可以在update语句中使用它来创建该seq类型的属性:

var update =  { $inc : { seq : mongo.Long(1) } };

这似乎也将seq现有文档的属性转换为NumberLong.

于 2015-07-21T17:10:00.937 回答