works great, thanks george!

does anybody know if this is possible to do directly with the ORM?


On May 7, 10:41 pm, George Song <geo...@damacy.net> wrote:
> On 5/7/2009 4:28 PM, Andy Lei wrote:
>
>
>
> > I have 3 models.  Something like this:
>
> > Writer:
> >      content = ManyToMany(Content)
> > Content
> >      tags = ManyToMany(Tag)
> > Tag
>
> > Now suppose I have a Tag, call it "tag1".  The idea of the query is
> > that I want the Writers that have the most pieces of Content tagged
> > with tag1.
>
> > Theoretically, it'd be something like
> > Writer.objects.annotate(content_count=Count
> > ("content__tags=tag1")).order_by('content_count")
>
> > Obviously, that doesn't work.  Any help would be greatly appreciated.
>
> Hmm. I'm not sure if this is possible through the ORM. If it is, it's
> beyond me.
>
> The closest thing I can think of is:
> {{{
> Writer.objects.filter(content__in=Content.objects.filter(tags=tag))
>
> }}}
>
> Which will yield a QuerySet with each Writer repeated n times (once for
> each Content associated with that writer, tagged with `tag`).
>
> You should be able to do something in Python to get the Writer:count()
> mapping that you want.
>
> --
> George
--~--~---------~--~----~------------~-------~--~----~
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