/ / mgo find単一の値の配列を文字列に変換します-mongodb、go、mgo

mgo find単一値の配列を文字列に変換する - mongodb、go、mgo

これは、mongodbの私のコレクションスキーマの一部です。

{ "_id" : ObjectId("55e1eef5255da6d384754642"), "name" : [ "Web, Mobile & Software Dev", "Movil y desarrollo de software" ] } { "_id" : ObjectId("55e1f2d0255da6d38475464b"), "name" : [ "IT & Networking", "TI y Redes" ] } ...

今私はこのような情報を得ることができます:

 err := r.Coll.Find(bson.M{}).Select(bson.M{"name": bson.M{"$slice": []int{1, 1}}}).All(&result.Data)

しかし、「名前」が単一値の配列の代わりに文字列を返すようにしたいので、必要がない場合はフロントエンド内でインデックスを付ける必要はありません。

回答:

回答№1は0

非常に限られたコメント私の投稿を編集し、思われるものを追加するには2000ポイントが必要です。これは答えではありませんが、おそらくループする必要がありますか?、より良い方法ではありませんか?

err := r.Coll.Find(bson.M{}).Select(bson.M{"name": bson.M{"$slice": []int{1, 1}}}).All(&result.Data)
if err != nil {
return result, err
}

type skillnew struct {
Id   bson.ObjectId `json:"id,omitempty" bson:"_id,omitempty"`
Name string        `bson:"name,omitempty" json:"name,omitempty"`
}

skillsallnew := make([]skillnew, len(result.Data))
for i := range result.Data {
skillsallnew[i] = skillnew{result.Data[i].Id, result.Data[i].Name[0]}
}