sql >> Databáze >  >> NoSQL >> MongoDB

Jak vytvořím textový index v mongodb pomocí golang a knihovny mgo?

Toto je podporováno v ovladači. Vše, co musíte udělat, je definovat vaše pole, která mají být indexována jako „text“ jako v $text:field .

V kompletním seznamu:

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

}

Což při pohledu z mongo shell dá:

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



  1. Vrátí konkrétní pole z kolekce objektů

  2. Jak uložit pouze datovou část s mangustou, nikoli ve formátu ISODate

  3. MongoDB na počítači se systémem Windows 7:Nelze vytvořit žádné připojení

  4. MongoDB:Jaký je dobrý způsob, jak získat seznam všech jedinečných značek?