I'm not sure I completely understand the problem, but I'll give it a
stab:

events = Event.objects.filter(start__gte=datetime.today())
locations = Location.objects.filter(location__in=events)

results = [
   {'start': loc.location.start, 'title': loc.location.title, 'id':
loc.location.id, 'state_id': loc.state.id, 'name': loc.name} \
   for loc in locations.iterator()
]

render_to_response('template.htm', {'results': results})

I run a query similar to this one on a 50,000 record table and it only
takes ~0.30 seconds, and that includes Json serialization!

On Jun 17, 5:00 pm, Sam Walters <mr.sam...@gmail.com> wrote:
> Here is the essentials from my models.py file:
> --------------------------------------------------------------------------------------------------------
> class Event (models.Model):
>         contact = models.CharField(max_length=100)
>         email = models.CharField(max_length=100)
>         url = models.CharField(max_length=100)
>         title = models.CharField(max_length=100)
>         start = models.DateTimeField('date time when')
>         end = models.DateTimeField('date till')
>
> class Location (models.Model):
>     name = models.CharField(max_length=50)
>     state = models.ForeignKey(State)
>     location = models.ForeignKey(Event)
> --------------------------------------------------------------------------------------------------------
> This is a One-to-Many Relationship where an Event can have one or more
> Locations.
>
> The problem i need to solve is in the 'views.py' I want to be able to
> query 'Event' such that i retrieve an arbitrary subset of events AND
> any associated Locations and return only the relevant fields to the
> template layer.
>
> The most standard use for this database will be to get all events from
> today into the future and their associated locations. On average there
> would be say 25 event rows returned and perhaps 27 locations as some
> events have more than one location.
> --------------------------------------------------------------------------------------------------------
> e_future = Event.objects.filter(start__gte = datetime.today())
> --------------------------------------------------------------------------------------------------------
> having readhttp://docs.djangoproject.com/en/dev/topics/db/queries/
>
> i realise i can use a reverse foreign key to access an item in the
> Location table:
> --------------------------------------------------------------------------------------------------------
> for e in e_future:
>     e_location=e.location_set.all()
> --------------------------------------------------------------------------------------------------------
> From here it gets messy as i have to deal with the individual event
> elements 'e' out of a queryset 'e_future' and then reassemble the
> elements back into a queryset *i dont know how to do this* so my
> method can return the selected columns:
> --------------------------------------------------------------------------------------------------------
> e_future_subset = e_future.values('start', 'title','id',)
> e_location_subset = e_location.values('state_id', 'name',)
> --------------------------------------------------------------------------------------------------------
> Then i have to combine the two objects 'e_future_subset' and
> 'e_location_subset' (which i believe are dictionaries) and return the
> result.
> --------------------------------------------------------------------------------------------------------
> e_all = e_future_subset + e_location_subset
> return render_to_response('events.html', { 'e_all': e_all,})
> --------------------------------------------------------------------------------------------------------
>
> As you can see I have been researching the solution and i'm stuck only
> on a couple of points.
> Surely this is one of the most common requirements for a django setup
> where the 'model.py' describes a number of related tables 'one-to-
> many' 'one-to-one' or 'many-to-many' relationships, a query (or number
> of queries) are made and results are returned from multiple tables
> based on an entry's 'id' and accessed through foreign-key pointers.
>
> Any help would be greatly appreciated as I seem to have a handle on
> everything else in my django project.
--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-users@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
-~----------~----~----~----~------~----~------~--~---

Reply via email to