Skip to content
World Wide Web Server edited this page Jul 4, 2012 · 18 revisions

Category:Database

[h3]Nested Sets - Working with hierarchical data trees[/h3]

One of the most commonly used methods of representing trees of data within a database is the adjacency list model, where each record has a column dedicated to identifying the 'parent' record for this particular row of data. Using the parent identifier it becomes possible to work your way up from any node in the tree back to the uppermost parent or ancestor (also commonly referred to as the root node). In this way, you can recurse through the tree data and build up programmatically an array structure representing the tree.

However, this recursion business is somewhat expensive in terms of processor cycle consumption.

Enter then, an appropriate alternative method for handling tree data suited to situations where the tree needs to be read much more often than it needs to be changed or modified.

[strong]Nested sets, or the modified preorder inverse tree traversal[/strong]

The nested sets approach involves giving each node of the tree two integer references, one on its left hand side and the other on its right hand side. The left hand side of the root node is always '1'. The rest of the tree is numbered by travelling down the left hand side and up the right hand side of every node until you get back to the right hand side of the root node, where the number used will be exactly twice the number of nodes in the tree. Please see the reference articles for further information on this.

[h3]Nested_sets_model.php[/h3]

This is the heart of the machine; the model class that actually does the reading, writing and manipulation of the tree. It is [strong]not[/strong] intended to be used directly by your controllers, rather to be extended by another model class that you write in order to give it the "character" required. In this sense, it really ought to be an abstract class, which is how I wrote it in the first place before remembering that PHP4.x doesn't support abstract classes. Consequently, I've rewritten it a little to make it compatible with PHP4.x installations. PHP5 users can use it as it is, a concrete class, or mod it back to being an abstract class as they see fit.

This base class is extended in the usual fashion: [code] class Categories_model extends Nested_sets_model { function Categories_model() { parent::Model(); } } [/code]

The extending class should provide the properties for the table name to use, as well as identifying the column names of the left value, the right value and the primary key (where appropriate).

[h3]Categories_demo files[/h3]

Also included in the package are files to provide a demo, using the notion of categories and subcategories for our data tree. Included is a controller, a model and a view, which can be dropped into the relevant locations to enable the demo. This also illustrates how the Nested_sets_model base class is extended for use within the application.

[h3]Download the package[/h3] File:CI_nested_sets.zip

[h3] References [/h3] [url=http://www.dbmsmag.com/9604d06.html]DBMS Online magazine: Joe Celko article[/url] [url=http://www.sitepoint.com/article/hierarchical-data-database/2]Sitepoint article: Hierarchical Data in a Database[/url] [url=http://www.edutech.ch/contribution/nstrees/index.php]Nested Set trees[/url]

Clone this wiki locally