views:

38

answers:

1

I am trying to lower the amount of queries that my django app is using, but I am a little confused on how to do it.

I would like to get a query set with one hit to the database and then filter items from that set. I have tried a couple of things, but I always get queries for each set.

let's say I want to get all names from my DB, but also separate out the people just named Ted. Both the names and the ted set will be used in the template.

This will give me two sets, one with all names and one with Ted.. but also hits the database twice:

namelist = People.objects.all()

tedList = namelist.filter(name='ted')

Is there a way to filter the first set without hitting the data base again?

A: 
tedList = [person for person in namelist if person.name == 'ted']

This will filter the initial QueryList on the client side.

Ignacio Vazquez-Abrams
Thanks! That did it.
chris
There's a good chance that the DB query would be faster - databases are optimized for this sort of thing.If someone were to actually test both methods, I'd be interested in seeing the results.
Chris Lawlor