Заказ Джанго-мптт - PullRequest
       13

Заказ Джанго-мптт

8 голосов
/ 29 октября 2011

В своем проекте я использую django-mptt для категорий.

Моя модель:

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)

И мне нужно иметь возможность получать заказ для текущей категории, например:

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

Как быстро заполнить / пересчитать столбец заказа при создании / перемещении элементов.Или рассчитать его по методу категории Category.objects.get(name='sub11b').get_order() должен вернуть 1.

Ответы [ 2 ]

10 голосов
/ 03 февраля 2012

При определении модели вы можете указать порядок с помощью "order_insertion_by".

Примерно так:

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

    class MPTTMeta:
        order_insertion_by = ['name']

Затем вы можете перестроить свою базу данных с помощью Category.tree.rebuild(), что должно соответствоватьуказанный порядок.

2 голосов
/ 05 января 2017

В последних версиях mptt (например, 0.8.7 ) следует использовать поле 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']
...