在我的项目中,我使用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的方法计算,Category.objects.get(name='sub11b').get_order()应该返回1。
发布于 2012-02-03 20:11:49
在定义模型时,您可以使用"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()重新构建数据库,它应该遵守指定的顺序。
发布于 2017-01-05 17:08:56
对于最新的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']https://stackoverflow.com/questions/7937130
复制相似问题