这是我的电话:
SomeCollection.insert(Inserts, {'w': 1, 'keepGoing': true}, function(Err, Result) {
//Callback logic goes here
});
现在,我猜测:
我发现API(http://mongodb.github.io/node-mongodb-native/1.4/api-generated/collection.html#insert)在这个问题上非常模糊。
我可能不得不运行一些测试和/或查看源代码,以便稍后发布答案,除非有人知道:)...
答案 0 :(得分:2)
我写了并运行了这个脚本:
var MongoDB = require('mongodb');
MongoDB.MongoClient.connect("mongodb://localhost:27017/test", {native_parser:true}, function(Err, DB) {
DB.createCollection('TestCollectionInsertCallback', function(Err, TestCollection) {
TestCollection.ensureIndex({'UniqueIndex': 1}, {'w': 1, 'unique': true}, function(Err, Index) {
TestCollection.insert([{'UniqueIndex': 1}, {'UniqueIndex': 2}, {'UniqueIndex': 3}, {'UniqueIndex': 6}], {'w': 1, 'keepGoing': true}, function(Err, Result) {
console.log('\nSuccessful Inserts Args...');
console.log('Err:');
console.log(Err);
console.log('Result:');
console.log(Result);
TestCollection.insert([{'UniqueIndex': 1}, {'UniqueIndex': 2}, {'UniqueIndex': 3}, {'UniqueIndex': 6}], {'w': 1, 'keepGoing': true}, function(Err, Result) {
console.log('\nComplete Failure Inserts Args...');
console.log('Err:');
console.log(Err);
console.log('Result:');
console.log(Result);
TestCollection.insert([{'UniqueIndex': 4}, {'UniqueIndex': 5}, {'UniqueIndex': 6}, {'UniqueIndex': 7}], {'w': 1, 'keepGoing': true}, function(Err, Result) {
console.log('\nPartial Success Inserts Args...');
console.log('Err:');
console.log(Err);
console.log('Result:');
console.log(Result);
TestCollection.find({}).toArray(function(Err, Results) {
console.log('\nFinal DB content...');
Results.forEach(function(Item, Index, List) {
console.log(Item);
});
DB.dropCollection('TestCollectionInsertCallback', function(Err, Result) {
DB.close();
});
});
});
});
});
});
});
});
输出结果为:
Successful Inserts Args...
Err:
null
Result:
[ { UniqueIndex: 1, _id: 5446084afa57911715f18c4e },
{ UniqueIndex: 2, _id: 5446084afa57911715f18c4f },
{ UniqueIndex: 3, _id: 5446084afa57911715f18c50 },
{ UniqueIndex: 6, _id: 5446084afa57911715f18c51 } ]
Complete Failure Inserts Args...
Err:
{ [MongoError: E11000 duplicate key error index: test.TestCollectionInsertCallback.$UniqueIndex_1 dup key: { : 6 }]
name: 'MongoError',
err: 'E11000 duplicate key error index: test.TestCollectionInsertCallback.$UniqueIndex_1 dup key: { : 6 }',
code: 11000,
n: 0,
connectionId: 88,
ok: 1 }
Result:
null
Partial Success Inserts Args...
Err:
{ [MongoError: E11000 duplicate key error index: test.TestCollectionInsertCallback.$UniqueIndex_1 dup key: { : 6 }]
name: 'MongoError',
err: 'E11000 duplicate key error index: test.TestCollectionInsertCallback.$UniqueIndex_1 dup key: { : 6 }',
code: 11000,
n: 0,
connectionId: 90,
ok: 1 }
Result:
null
Final DB content...
{ UniqueIndex: 1, _id: 5446084afa57911715f18c4e }
{ UniqueIndex: 2, _id: 5446084afa57911715f18c4f }
{ UniqueIndex: 3, _id: 5446084afa57911715f18c50 }
{ UniqueIndex: 6, _id: 5446084afa57911715f18c51 }
{ UniqueIndex: 4, _id: 5446084afa57911715f18c56 }
{ UniqueIndex: 5, _id: 5446084afa57911715f18c57 }
{ UniqueIndex: 7, _id: 5446084afa57911715f18c59 }
因此,问题中提供的案例的答案是:
答案 1 :(得分:1)
以这种方式思考:Err只能是null或JavaScript Error对象的实例。 “部分成功”意味着至少发生了一个错误,因此该方法将返回一个错误,您需要在回调中处理该错误。错误的“消息”属性通常会告诉您需要知道的内容。
根据我的经验,node.js库的大多数文档都很模糊(有时候,不存在)。在开发过程中,阅读源代码甚至只是将结果打印到控制台是非常必要的。
有关节点中错误处理的更多信息,请查看this blog post。
希望这有帮助。