我喜欢在流星的集合中一次添加多个文档。
MongoDB从 2.2 开始支持这一点:
db.collection.insert([{docNumber: 1},{docNumber: 2}])
是否有可能在 Meteor 中实现这种行为?就像是:
myCollection.insert([{docNumber: 1},{docNumber: 2}])
目前这将被添加为一个文档。不幸的是,我不能忍受迭代器,因为用例正在加载超过 100'000 个文档。单次插入会减慢速度。
Meteor 尚无法进行批量插入。尽管您可以创建一个迭代器来帮助您将文档插入数组
var docs = [{docNumber: 1},{docNumber: 2}];
_.each(docs, function(doc) {
myCollection.insert(doc);
});
可能可以在服务器端执行此操作,尽管需要进行一些修改以公开批量插入方法。问题是这个代码在客户端不起作用。
我写了一个简单的脚本来批量插入。它仅在客户端通过将文档插入集合而没有反应性地工作。只有最后一项会调用响应式计算。
insertBulk = function(collection, documents){
if(collection) {
return _.compact(_.map(documents, function(item){
if(_.isObject(item)) {
var _id = collection._makeNewID();
// insert with reactivity only on the last item
if(_.last(documents) === item)
_id = collection.insert(item);
// insert without reactivity
else {
item._id = _id;
collection._collection._docs._map[_id] = item;
}
return _id;
}
}));
}
}
您可以在此处找到包含 removebulk() 函数的示例脚本:https ://gist.github.com/frozeman/88a3e47679dd74242cab