I’m new to MongoDB. When creating a new table a question came to my mind related to how to design it and performance. My table structure looks this way:
{
"name" : string,
"data" : { "data1" : "xxx", "data2" : "yyy", "data3" : "zzz", .... }
}
The “data” field could grow until it reaches an amount of 100.000 elements ( “data100.000” : “aaaXXX”). However the number of rows in this table would be under control (between 500 and 1000).
This table will be accessed many times in my application and I’d like to maximize the performance of any queries. I would do queries like this one (I’ll put an example in java):
new Query().addCriteria(Criteria.where("name").is(name).and("data.data3").is("zzz"));
I don’t know if this would get slower when the amount of “dataX”… elements grows.
So the question is: Is this design correct? Should I change something?
I’ll be pleased to read your advice, many thanks in advance
A document could be viewed like a table with columns, but you have to be carefull. It has other usage characteristics. The document size can be max. 16 MB. And you have to keep in mind that the documents are hold in memory by mongo.
With your query the whole document will be returned. Ask yourself do you need all entries or
will you have to use a single entry on his own?
This should be a good start.