Thanks a lot, Atilla. `Question.objects.filter(answer__user=user).distinct()` returns exactly what I expect. This is wonderful, thanks a lot. I also recheck the django manual and found this solution has a name as "query over related objects" (http://www.djangoproject.com/documentation/ db_api/#queries-over-related-objects). This is really powerful yet simple enough.
Alex On Mar 9, 12:56 am, Atilla <[EMAIL PROTECTED]> wrote: > On 08/03/07, Alex Dong <[EMAIL PROTECTED]> wrote: > > > > > > > Hi all, > > > I have a data model like this: > > * a `user` has multiple `questions` > > * a `user` could give multiple `answer`s or `comment`s to any > > `question`s. > > So here, there are > > * a one-to-many relationship from `user` to `question` > > * a many-to-many relationship between `question` and `answer`, > > `question` and `comment`. > > Now I need to pull out a list of all the questions a given user has > > either answered or commented on. I could do `user.question_set` or > > `user.answer_set`. > > > Now if I write a template like this: > > ` {% for answer in user.answer_set %} > > ... {{ answer.question. ... }} > > {% endfor %} > > ` > > I could end up with showing the same questions many times. > > > I know for sure that this task is not that difficult if I retreat to > > using `JOIN` and use raw sql for my query. But I'm wondering does > > Django offers a neat solution for this question without using raw > > sql? > > > Thanks, > > Alex > > How about this: Question.objects.filter(answer__user_id=userID) - this > should give you the question objects for which the user has given > answers. Extend the filter with a Q clause to do the OR for comments. > You may need to throw a .distinct() in there as well. I've got a > similar thing that works, I'm just not sure about the exact syntax for > your case. --~--~---------~--~----~------------~-------~--~----~ 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 [EMAIL PROTECTED] For more options, visit this group at http://groups.google.com/group/django-users?hl=en -~----------~----~----~----~------~----~------~--~---