I am trying to do something that I think is quite simple. Suppose I have a series of records in mongo that have a common key, and variable number of attributes. I want to select
The solution from Stennie requires you to know exactly which attributes you want to return from each matching item in the collection you're querying. This isn't always the case.
We had to solve this problem within a Groovy on Grails application we're writing.
We wrote a method like this to handle the "find by X" requests:
private List findDistinctPages(Map by) {
def command =
new GroupCommand(
(DBCollection) db.pages,
new BasicDBObject(['url': 1]),
new BasicDBObject(by),
new BasicDBObject([:]),
'function ( current, result ) { for(i in current) { result[i] = current[i] } }',
''
)
db.pages.group(command).sort { it.title }
}
And then call it within our code as follows:
def pages = findDistinctPages([$or: [[type: 'channel'], [type: 'main']]])
This works by passing the results of the initial query to the javascript function at the end of the GroupCommand. Mongo only returns the attributes you specify in the initial query and nothing else, so you then have to iterate over the results a 2nd time, populating them with the rest of the data from mongo.