2011-10-29 13 views
8

W moim projekcie używam django-mptt dla kategorii.Zamówienie Django-mptt

Mój model:

class Category(models.model): 
    name = models.CharField() 
    parent = models.ForeignKey("self", blank=True, null=True, 
          related_name="sub_category") 
    nav_order = models.IntegerField(null=False, blank=False, default=0) 
    # unsure need nav_order column in DB 

    class Meta: 
     verbose_name_plural = 'Categories' 
mptt.register(Category) 

I muszę mieć zdolność porządkowania dla bieżącej kategorii tak:

Category    Navigation order(one column) 

CatA      0 
|-subcat11     0 
    |-sub11a     0 
    |-sub11b     1 
    \-sub11c     2 
\-subcat12     1 
CatB      1 
|-subcat21     0 
|-subcat22     1 
\-subcat23     2 
    \-sub23a     0 
CatC      2 

Jak mogę szybko napełnić/przeliczyć kolumnę zlecenia na tworzenie/ruchome elementy. Lub obliczyć według metody kategorii Category.objects.get(name='sub11b').get_order() powinien zwrócić 1.

Odpowiedz

10

Podczas definiowania modelu można określić porządek za pomocą "order_insertion_by".

Więc coś takiego:

class Category(MPTTModel): 
    name = models.CharField() 
    parent = models.ForeignKey("self", blank=True, null=True, 
      related_name="sub_category") 

    class MPTTMeta: 
     order_insertion_by = ['name'] 

Następnie można odbudować bazę danych z Category.tree.rebuild() która powinna być zgodna z określoną kolejność.

+3

Z 'django-mptt' wersji 0.8.3, polecenie uruchomienia jest' Category.objects.rebuild() ' . –

2

Z ostatnich mptt wersjach (np 0.8.7) należy użyć pola TreeForeignKey:

from mptt.models import MPTTModel 
from mptt.fields import TreeForeignkey 

class Category(MPTTModel): 
    name = models.CharField() 
    parent = TreeForeignKey("self", 
          blank=True, 
          null=True, 
          related_name="sub_category") 

    class MPTTMeta: 
     order_insertion_by = ['name']