如何通过 mgo (golang) 创建散列索引

How to create hashed index by mgo (golang)

如何使用 mgo 包创建(或确保)散列索引?

我需要一个与此等效的 go 代码:

>> db.collection.createIndex( { _id: "hashed" } )

我试过使用 runCommand,但只有 ‍createIndexes 命令需要 index specs 的列表。我不知道那是什么以及如何创建 index specs.

您可以按照 Collection.EnsureIndex 中的说明进行操作:

Other kinds of indexes are also supported through that API. Here is an example:

index := Index{
    Key: []string{"d:loc"},
    Bits: 26,
}
err := collection.EnsureIndex(index)

The example above requests the creation of a "2d" index for the "loc" field.

所以基本上,您的格式是 $<indexType>:<indexedField>,如下所示:

package main

import mgo "gopkg.in/mgo.v2"

const (
    db   = "so_hashed_idx"
    coll = "testcoll"
)

func main() {
    var s *mgo.Session
    var err error

    if s, err = mgo.Dial("127.0.0.1:27017"); err != nil {
        panic(err)
    }

    // An index spec is nothing more than a fancy word for the keys
    // or the key/value pairs handed over to the Key slice of the
    // Index type.
    idx := mgo.Index{
        Key: []string{"$hashed:_id"},
    }

    if err := s.DB(db).C(coll).EnsureIndex(idx); err != nil {
        panic(err)
    }
}

构建和 运行 以上结果 so_hashed_idx.testcoll 显示其索引如下

> db.testcoll.getIndices()
[
    {
        "v" : 1,
        "key" : {
            "_id" : 1
        },
        "name" : "_id_",
        "ns" : "so_hashed_idx.testcoll"
    },
    {
        "v" : 1,
        "key" : {
            "_id" : "hashed"
        },
        "name" : "_id_hashed",
        "ns" : "so_hashed_idx.testcoll"
    }
]

回答runCommand

func createHashedIndex(session *mgo.Session, collectionName string, indexKey string){
    var result interface{}
    if err := session.Run(bson.D{
        {"createIndexes", collectionName},
        {"indexes", []bson.M{bson.M{"name": indexKey+"_hashed_index", "key": bson.M{indexKey: "hashed"}}}}}, &result); err != nil {
        fmt.Println("Create Index Error:", err.Error())
    } else {
        fmt.Println("Create Index:", result)
    }
}