Node.js MongoDB创建多个索引:没有指定索引名

时间:2016-05-08 14:36:57

标签: node.js mongodb indexing

我正在使用MongoDB版本2.6.11

如何修复此错误?在Node.js API reference中,您可以传递的唯一参数是索引规范数组和回调函数,我在哪里指定索引名称?我正在使用的代码如下(假设我已经需要mongoclient并连接到数据库):

db.collection("MyCollection").createIndexes(
    [
        {field1: 1}, 
        {field2: 1, field3: 1}
    ], 
    function(err, result){
        //Error handling code
    }
);

错误代码为67,错误的完整堆栈跟踪如下:

MongoError: no index name specified
    at Function.MongoError.create (/home/ubuntu/workspace/node_modules/mongodb/node_modules/mongodb-core/lib/error.js:31:11)
    at commandCallback (/home/ubuntu/workspace/node_modules/mongodb/node_modules/mongodb-core/lib/topologies/server.js:1154:66)
    at Callbacks.emit (/home/ubuntu/workspace/node_modules/mongodb/node_modules/mongodb-core/lib/topologies/server.js:119:3)
    at messageHandler (/home/ubuntu/workspace/node_modules/mongodb/node_modules/mongodb-core/lib/topologies/server.js:295:23)
    at Socket.dataHandler (/home/ubuntu/workspace/node_modules/mongodb/node_modules/mongodb-core/lib/connection/connection.js:285:22)
    at emitOne (events.js:77:13)
    at Socket.emit (events.js:169:7)
    at readableAddChunk (_stream_readable.js:146:16)
    at Socket.Readable.push (_stream_readable.js:110:10)
    at TCP.onread (net.js:529:20)

我连接数据库后立即运行此命令。如果数据库是新的,那么该集合将不存在,任何具有指定字段的文档也不会被索引,这可能是问题吗?

1 个答案:

答案 0 :(得分:2)

您需要按照here所述指定索引。

所以你的调用应该是这样的,而不是为每个索引提供一个唯一的名称:

db.collection("MyCollection").createIndexes(
    [
        {name: 'field1', key: {field1: 1}}, 
        {name: 'field2_field3', key: {field2: 1, field3: 1}}
    ], 
    function(err, result){
        //Error handling code
    }
);