Django:过滤自引用外键属性



在我的 Django 2.2 应用程序中,我有一个这样的模型:

class Folder(models.Model):
name = models.CharField(max_length=100)
parent_folder = models.ForeignKey("Folder", null=True, on_delete=models.SET_NULL)

基本上,文件夹可以有父文件夹,此文件夹的父文件夹本身可以有父级,依此类推。

所以我想做的是,根据文件夹的name属性对文件夹进行排序,从顶级文件夹(因此,没有parent_folder的文件夹(开始,然后在文件夹层次结构中降序。

为了说明这一点,给定表中的以下对象:

+----+---------+---------------+
| id |  name   | parent_folder |
+----+---------+---------------+
|  1 | fuel    | <None>        |
|  2 | blabla  | 1             |
|  3 | volcano | 2             |
|  4 | awful   | 2             |
|  5 | apple   | 1             |
|  6 | amazing | <None>        |
|  7 | wow     | 6             |
+----+---------+---------------+

排序输出 I 除外:

+----+---------+---------------+
| id |  name   | parent_folder |
+----+---------+---------------+
|  6 | amazing | <None>        |
|  7 | wow     | 6             |
|  1 | fuel    | <None>        |
|  5 | apple   | 1             |
|  2 | blabla  | 1             |
|  4 | awful   | 2             |
|  3 | volcano | 2             |
+----+---------+---------------+

我建议为此使用django-mptt,可以通过pip3 install django-mptt安装。

mptt添加到INSTALLED_APPS,然后修改模型:

from mptt.models import MPTTModel, TreeForeignKey
class Folder(MPTTModel):
name = models.CharField(max_length=100)
parent = TreeForeignKey('self', on_delete=models.CASCADE, blank=True, null=True)

现在,您只需调用Folder.get_family(),默认情况下,查询集将按"树顺序"排序。

可以通过使用 Django MPTT 轻松实现。

您需要的内容由.get_family()返回(请参阅文档(。

最新更新