2011-10-29 12 views
8

Nel mio progetto sto usando django-mptt per le categorie.Ordine Django-

Il mio modello:

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) 

E ho bisogno di avere la capacità nell'ordinare per la categoria corrente in questo modo:

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 

Come posso rapidamente riempire/ricalcolare colonna ordine sulla creazione/elementi in movimento. o calcolarlo per metodo di categoria Category.objects.get(name='sub11b').get_order() deve restituire 1.

risposta

10

Quando si definisce il modello è possibile specificare l'ordine con "order_insertion_by".

Quindi qualcosa di simile:

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

    class MPTTMeta: 
     order_insertion_by = ['name'] 

Quindi è possibile ricostruire il database con Category.tree.rebuild() che dovrebbe rispettare l'ordinamento specificato.

+3

Con 'django-mptt' versione 0.8.3, il comando da eseguire è' Category.objects.rebuild() ' . –

2

Con i recenti mptt versioni (ad esempio 0.8.7) si dovrebbe utilizzare il campo 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']