Utilities for implementing Modified Preorder Tree Traversal with your Django Models and working with trees of Model instances.
Project description
This project is currently unmaintained
django-mptt works by storing pre-computed left/right/level/tree_id values alongside each row. This makes reads very fast, but it means that every insert, move, or delete must update a potentially large number of sibling and ancestor rows. This write amplification is the fundamental reason the library is hard to maintain: concurrent writes can race and corrupt the tree, bulk operations bypass the update logic entirely, and any code that touches the database outside of django-mptt (raw SQL, bulk_update, migrations) can leave the tree in an inconsistent state. Rebuilding with rebuild() is the escape hatch, but it locks the table.
If you are starting a new project, or can afford to migrate, consider an alternative. Newer databases support recursive Common Table Expressions (CTE), which let you store only a parent FK and compute ancestry on the fly. See django-tree-queries for such an implementation and its announcement blog post. Other alternatives are listed on Django Packages.
django-mptt itself is kept alive on a best-effort basis — bugs get fixed when reported with a clear reproduction, compatibility with new Django versions is maintained, but new features will not be added.
django-mptt
Utilities for implementing Modified Preorder Tree Traversal with your Django Models and working with trees of Model instances.
Project home: https://github.com/django-mptt/django-mptt/
Documentation: https://django-mptt.readthedocs.io/
Discussion group: https://groups.google.com/forum/#!forum/django-mptt-dev
What is Modified Preorder Tree Traversal?
MPTT is a technique for storing hierarchical data in a database. The aim is to make retrieval operations very efficient.
The trade-off for this efficiency is that performing inserts and moving items around the tree are more involved, as there’s some extra work required to keep the tree structure in a good state at all times.
Here are a few articles about MPTT to whet your appetite and provide details about how the technique itself works:
What is django-mptt?
django-mptt is a reusable Django app that aims to make it easy for you to use MPTT with your own Django models.
It takes care of the details of managing a database table as a tree structure and provides tools for working with trees of model instances.
Requirements
A supported version of Python: https://devguide.python.org/versions/#supported-versions
A supported version of Django: https://www.djangoproject.com/download/#supported-versions
Feature overview
Simple registration of models - fields required for tree structure will be added automatically.
The tree structure is automatically updated when you create or delete model instances, or change an instance’s parent.
Each level of the tree is automatically sorted by a field (or fields) of your choice.
New model methods are added to each registered model for:
changing position in the tree
retrieving ancestors, siblings, descendants
counting descendants
other tree-related operations
A TreeManager manager is added to all registered models. This provides methods to:
move nodes around a tree, or into a different tree
insert a node anywhere in a tree
rebuild the MPTT fields for the tree (useful when you do bulk updates outside of Django)
Form fields for tree models.
Utility functions for tree models.
Template tags and filters for rendering trees.
Admin classes for visualizing and modifying trees in Django’s administration interface.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file django_mptt-0.19rc1.tar.gz.
File metadata
- Download URL: django_mptt-0.19rc1.tar.gz
- Upload date:
- Size: 72.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
29a3ed8c28b83b777655aa2045634aad81c566b8a6f1f4c0a937473967b84521
|
|
| MD5 |
fce0417b0a27e03efabdd7f47221f06f
|
|
| BLAKE2b-256 |
556e410783f08ec3e9ae31287f7749f86eadaa659aa955d5764a85700d2b36ff
|
Provenance
The following attestation bundles were made for django_mptt-0.19rc1.tar.gz:
Publisher:
publish.yml on django-mptt/django-mptt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
django_mptt-0.19rc1.tar.gz -
Subject digest:
29a3ed8c28b83b777655aa2045634aad81c566b8a6f1f4c0a937473967b84521 - Sigstore transparency entry: 1702094675
- Sigstore integration time:
-
Permalink:
django-mptt/django-mptt@1b1b5c57c106b1de2daa5041d9b24a46bb2dcabf -
Branch / Tag:
refs/tags/0.19rc1 - Owner: https://github.com/django-mptt
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@1b1b5c57c106b1de2daa5041d9b24a46bb2dcabf -
Trigger Event:
push
-
Statement type:
File details
Details for the file django_mptt-0.19rc1-py3-none-any.whl.
File metadata
- Download URL: django_mptt-0.19rc1-py3-none-any.whl
- Upload date:
- Size: 121.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a4c3383e8a951ac6b71c3342ee2edfe6f99865595a305cbcb941765ab52398e6
|
|
| MD5 |
590ca2cefdb89e45cb08062e8fc12260
|
|
| BLAKE2b-256 |
838f72ce05cdfc465e2feb8a7481c7b81b7541a9f3f81ca0774826af4b148df4
|
Provenance
The following attestation bundles were made for django_mptt-0.19rc1-py3-none-any.whl:
Publisher:
publish.yml on django-mptt/django-mptt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
django_mptt-0.19rc1-py3-none-any.whl -
Subject digest:
a4c3383e8a951ac6b71c3342ee2edfe6f99865595a305cbcb941765ab52398e6 - Sigstore transparency entry: 1702094697
- Sigstore integration time:
-
Permalink:
django-mptt/django-mptt@1b1b5c57c106b1de2daa5041d9b24a46bb2dcabf -
Branch / Tag:
refs/tags/0.19rc1 - Owner: https://github.com/django-mptt
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@1b1b5c57c106b1de2daa5041d9b24a46bb2dcabf -
Trigger Event:
push
-
Statement type: