On Feb 24, 8:08 am, Timothy Kinney <timothyjkin...@gmail.com> wrote: > I have models which describe a game. There are 61 provinces with 9 > rooms in each province, for a total of 549 locations. There are > several hundred samurai, each assigned to a particular room id. > > Province(name, id, exits) > Room(id, name, foreignkey('Province')) > Samurai(id, name, foreignkey('Room')) > > I want to display a list of samurai (by id) for each province on the > admin/change_list.html. > > I created a method in the Province model: > > def samurai(self): > r = self.room_set.filter(province = self.pk).all() > output = [] > for i in r: > output.extend(i.samurai()) > return unicode(output) > > I use list_detail.object_list as the generic view and call the > province.samurai method from my template: > > {% for province in object_list %} > <tr> > <td>{{ province.name }} [{{ province.id }}] </td> > <td>{{ province.exits }}</td> > <td>{{ province.samurai }} </td> > </tr> > {% endfor %} > > This is very slow, taking almost 4 seconds for 260 samurai. > > I know that the reason this is slow is because I am hitting the > database so inefficiently. I have a for loop where each province is > iterating 9 times and I am iterating this loop 61times. > > I'm new to databases and to django, so I'm trying to understand how I > can grab all the data in one query and then just use it. I think I > should do this from the view? > > Can you give me a list of steps (in pseudo-code) for optimizing this > query? > > eg: > 1) Get all objects in province from the view > 2) create a dictionary > 3) and so on... > > I just don't grok how the template, view, model method, and ORM fit > together to make an efficient query. :/ > > -Tim
You've identified the problem correctly, and the solution is fairly complicated because it's a three-level relationship. Without wanting to pimp my own blog, I've written quite a bit about patterns of query optimisation which might help you to see the sort of thing you need to do. See for example http://blog.roseman.org.uk/2010/jan/11/django-patterns-part-2-efficient-reverse-lookups/ -- DR. -- You received this message because you are subscribed to the Google Groups "Django users" group. To post to this group, send email to django-us...@googlegroups.com. To unsubscribe from this group, send email to django-users+unsubscr...@googlegroups.com. For more options, visit this group at http://groups.google.com/group/django-users?hl=en.