Thanks.. I think that will work.. will try it out shortly!

On Oct 8, 11:08 am, "Richard Dahl" <[EMAIL PROTECTED]> wrote:
> I have a model class 'Organization' with a parent and I do this with a
> method get_child_orgs:
>
> get_child_orgs(self):
>     child_orgs = []
>     co = Organization.objects.filter(parent__exact = self)
>     for c in co:
>         child_orgs.append(c)
>         gc = c.get_child_orgs()
>         child_orgs.extend(gc)
>     return child_orgs
>
> On 10/8/07, [EMAIL PROTECTED] <[EMAIL PROTECTED]> wrote:
>
>
>
> > Ok..thanks.. I was afraid I was going to get that answer.  If I do
> > this with select_related, I'm still going to have to implement a loop
> > to display them all in one list, because they'd come back as
> > company.parent_company.parent_company etc, instead of all in one top
> > level list... right?
>
> > On Oct 8, 9:19 am, Malcolm Tredinnick <[EMAIL PROTECTED]>
> > wrote:
> > > On Mon, 2007-10-08 at 13:13 +0000, [EMAIL PROTECTED] wrote:
> > > > In my model class I have:
>
> > > > class Company(models.Model):
> > > >     company_id = models.AutoField(primary_key=True)
> > > >     parent_company = models.ForeignKey("self",null=True)
> > > >     .
> > > >     .
>
> > > > How would I query to get back all children companies, as well as all
> > > > of their children companies, and their children companies, etc,
> > > > without writing a nested loop to do so?
>
> > > You can't do it with a general query because there's no way to do it in
> > > SQL with this data structure. The SQL has to do a join each time you
> > > query from parent back to child (or vice-versa), so we need to know the
> > > number of joins to create a query construction time.
>
> > > There is a "depth" parameter for select_related() queries that limits
> > > the number of recursion steps (otherwise infinite loops would result for
> > > queries like this) and you could use that to control the maximum number
> > > of children. However, I believe there are some bugs with it working for
> > > small values of depth (depth=1) and there might be others, so check the
> > > results carefully.
>
> > > Regards,
> > > Malcolm


--~--~---------~--~----~------------~-------~--~----~
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
-~----------~----~----~----~------~----~------~--~---

Reply via email to