これは、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]}
}