I´m trying to get a list of blog entries a certain user has authored but my query only returns the first entry created.
This is my User model
type User struct {
Id bson.ObjectId `bson:"_id,omitempty" json:"id"`
Name string `json:"name"`
}
and my BlogEntry model
type BlogEntry struct {
Id bson.ObjectId `bson:"_id,omitempty" json:"id"`
UserId bson.ObjectId `json:"user_id"`
Title string `json:"title"`
}
And this is my query for fetching all blog entries for a certain user
iter := service.Collection.Find(bson.M{"user_id": bson.ObjectIdHex(id)}).Iter()
Problem is, this only results in the FIRST entry for the user with the passed id.
I´ve checked the data and it seems correct, all the entries have a correct user_id field and so on.
Any ideas why I only get the first entry?
EDIT:
Complete implementation of my function that queries the entries.
func (service *BlogEntryService) GetEntryByUserId(id string) []models.BlogEntry {
var entries []models.BlogEntry
iter := service.Collection.Find(bson.M{"user_id": bson.ObjectIdHex(id)}).Iter()
result := models.BlogEntry{}
for iter.Next(&result) {
entries = append(entries, result)
}
return entries
}