I have a Mongo DB COllection as shown
{
"name": "SAM",
"collection": [
{
"date": "2013-03-16",
"values": [
{
"price": "24.0"
}
]
},
{
"date": "2013-04-20",
"values": [
{
"price": "10.0"
}
]
},
{
"date": "2013-05-18",
"values": [
{
"price": "12.0"
}
]
},
{
"date": "2013-06-22",
"values": [
{
"price": "10.0"
}
]
},
{
"date": "2013-09-21",
"values": [
{
"price": "38.0"
}
]
}
]
}
I was trying to get data related to a Particular date (2013-03-16) as shown But i am getting data of all the dates .
This is what i tried .
Please tell me where i am doing mistake .
package com;
import java.net.UnknownHostException;
import com.mongodb.BasicDBObject;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.DBCursor;
import com.mongodb.Mongo;
public class Test {
public static void main(String args[]) throws UnknownHostException {
Mongo mongo = new Mongo();
DB db = mongo.getDB("test");
DBCollection mycollection = db.getCollection("mycollection");
BasicDBObject query = new BasicDBObject();
query.put("name", "SAM");
query.put("collection.date", "2013-03-16");
DBCursor cursor = mycollection.find(query);
while (cursor.hasNext()) {
System.out.println(cursor.next());
}
}
}
$unwindoperator from the Aggregation Framework to break up the single document into a document per entry in the embedded array.