I want to be as efficient as possible and plan properly. Since read and write costs are important when using Google App Engine, I want to be sure to minimize those. I’m not understanding the “key” concept in the datastore. What I want to know is would it be more efficient to fetch an entity by its key, considering I know what it is, than by fetching by some kind of filter?
Say I have a model called User and a user has an array(list) of commentIds. Now I want to get all this user’s comments. I have two options:
-
The user’s array of commentId’s is an array of keys, where each key is a key to a Comment entity. Since I have all the keys, I can just fetch all the comments by their keys.
-
The user’s array of commentId’s are custom made identifiers by me, in this case let’s just say that they’re auto-incrementing regular integers, and each comment in the datastore has a unique commentIntegerId. So now if I wanted to get all the comments, I’d do a filtered fetch based on all comments with ID that is in my array of ids.
Which implementation would be more efficient, and why?
1 Answer