MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

Wie erstelle ich einen Textindex in mongodb mit golang und der mgo-Bibliothek?

Dies wird im Treiber unterstützt. Alles, was Sie tun müssen, ist, Ihre zu indexierenden Felder als "Text" wie in $text:field zu definieren .

In einer vollständigen Auflistung:

import (
  "labix.org/v2/mgo"
)

func main() {

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

  defer session.Close()

  session.SetMode(mgo.Monotonic, true)

  c := session.DB("test").C("texty")

  index := mgo.Index{
    Key: []string{"$text:name", "$text:about"},
  }

  err = c.EnsureIndex(index)
  if err != nil {
    panic(err)
  }

}

Was, wenn es von der Mongo-Shell aus betrachtet wird, Folgendes ergibt:

> db.texty.getIndices()
[
    {
            "v" : 1,
            "key" : {
                    "_id" : 1
            },
            "name" : "_id_",
            "ns" : "test.texty"
    },
    {
            "v" : 1,
            "key" : {
                    "_fts" : "text",
                    "_ftsx" : 1
            },
            "name" : "name_text_about_text",
            "ns" : "test.texty",
            "weights" : {
                    "about" : 1,
                    "name" : 1
            },
            "default_language" : "english",
            "language_override" : "language",
            "textIndexVersion" : 2
    }
]