File: ltree.rst

package info (click to toggle)
python-django-treebeard 5.0.5-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,048 kB
  • sloc: python: 5,271; javascript: 269; makefile: 178
file content (116 lines) | stat: -rw-r--r-- 3,373 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
PostgreSQL Ltree trees (experimental)
=====================================

.. module:: treebeard.ltree

This is an efficient tree implementation using PostgreSQL's `ltree`_ module. It requires
a PostgreSQL database.

This is currently an experimental implementation, open for testing and feedback from the community.

Treebeard uses a simple alphabet to generate path hierarchies for objects in the database. In order
to ensure efficient ordering, it uses an approach similar to the Materialized Path implementation
to use path values that match the desired order of nodes in the database.

To use the ``ltree`` module, you need to create the extension in your database:

   .. code-block:: psql
   
      CREATE EXTENSION IF NOT EXISTS ltree;

.. warning::

   As with all tree implementations, please be aware of the :doc:`caveats`.

.. inheritance-diagram:: LT_Node
.. autoclass:: LT_Node
  :show-inheritance:

  .. warning::

     Do not change the values of :attr:`path` directly. Use one of the included methods instead.
     Consider these values *read-only*.

  .. warning::

     Do not change the values of :attr:`node_order_by` after saving your first object. Doing so will
     result in objects being ordered incorrectly.

  .. warning::

     If you need to define your own
     :py:class:`~django.db.models.Manager` class,
     you'll need to subclass
     :py:class:`~LT_NodeManager`.

     Also, if in your manager you need to change the default
     queryset handler, you'll need to subclass
     :py:class:`~LT_NodeQuerySet`.


  Example:

  .. code-block:: python

     class SortedNode(LT_Node):
        node_order_by = ['numval', 'strval']

        numval = models.IntegerField()
        strval = models.CharField(max_length=255)

  Read the API reference of :class:`treebeard.models.Node` for info on methods
  available in this class, or read the following section for methods with
  particular arguments or exceptions.

  .. attribute:: node_order_by

     Attribute: a list of model fields that will be used for node
     ordering. When enabled, all tree operations will assume this ordering.
     This takes precedence over drag and drop ordering in the Django admin.

     Example:

     .. code-block:: python

       node_order_by = ['field1', 'field2', 'field3']

   .. warning::

      ``node_order_by`` values are used to determine correct node ordering *before*
         an object is inserted/moved. This means any fields that
         are auto-populated at a database level, e.g., ``AutoField()``, or ``DateTimeField(auto_now=True)``
         will be ignored for the purpose of ordering if a value isn't provided manually.

  .. attribute:: path

     ``ltree`` field, stores an ltree hierarchy for the node. The values are auto-generated
     by Treebeard from a simple alphabet.

  .. automethod:: add_root

     See: :meth:`treebeard.models.Node.add_root`

  .. automethod:: add_child

     See: :meth:`treebeard.models.Node.add_child`

  .. automethod:: add_sibling

     See: :meth:`treebeard.models.Node.add_sibling`

  .. automethod:: move

     See: :meth:`treebeard.models.Node.move`

  .. automethod:: get_tree

     See: :meth:`treebeard.models.Node.get_tree`

.. autoclass:: LT_NodeManager
  :show-inheritance:

.. autoclass:: LT_NodeQuerySet
  :show-inheritance:


.. _`ltree`: https://www.postgresql.org/docs/18/ltree.html