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

时间:2017-07-29 12:41:18

标签: mongodb go mgo

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

我需要一个go代码与此相同:

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

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

2 个答案:

答案 0 :(得分:2)

您可以按照Collection.EnsureIndex

中的说明进行操作
  

该API还支持其他类型的索引。这是一个例子:

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

上面的示例请求为“loc”字段创建“2d”索引。

基本上,您的格式为 $<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"
    }
]

答案 1 :(得分:2)

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)
    }
}