2011-10-29 12 views
8

En mi proyecto estoy usando django-mptt para las categorías.Orden Django-mptt

Mi modelo:

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) 

Y tengo que tener la capacidad para obtener por categoría actual como esto:

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 

¿Cómo puedo rápidamente llenado/recalcular columna de orden en la creación/elementos móviles. O calcule por el método de Categoría Category.objects.get(name='sub11b').get_order() debe devolver 1.

Respuesta

10

Al definir el modelo, puede especificar el pedido con "order_insertion_by".

Así que algo como esto:

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

    class MPTTMeta: 
     order_insertion_by = ['name'] 

A continuación, puede reconstruir su base de datos con Category.tree.rebuild() que debe respetar el orden especificado.

+3

con 'django-versión 0.8.3 mptt', el comando a ejecutar es' Category.objects.rebuild() ' . –

2

Con los recientes mptt versiones (por ejemplo 0.8.7) se debe utilizar el 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']