Python Django mptt订单

Python Django mptt订单,python,django,django-mptt,Python,Django,Django Mptt,在我的项目中,我将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=

在我的项目中,我将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
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的方法计算它
Category.objects.get(name='sub11b')。get\u order()
应该返回1。

定义模型时,可以使用“order\u insertion\u by”指定顺序

比如说:

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
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()
重建数据库,该数据库应遵守指定的顺序。

对于最新的
mptt
版本(例如),您应使用
TreeForeignKey
字段:

从mptt.models导入MPTTModel
从mptt.fields导入树键
类别(MPTTModel):
name=models.CharField()
parent=treeforeingkey(“self”,
空白=真,
空=真,
相关的_name=“子_类别”)
MPTTMeta类:
订单插入方式=['name']

对于
django mptt
0.8.3版,要运行的命令是
Category.objects.rebuild()