What is the best practice for fetching a tree of nodes from database for further rendering?
Asked Answered
G

2

7

Let's say we have a table with user comments. First-level comments have a reference to an article they are attached to. Deeper-level comments do not have this reference by design but they have a reference to it's parent comment.

For this database structure - what would be the most efficient way to fetch all comments for a given article and then render it in html format? (Let's assume that we have approx. 200 comments of first level and the deepiest level of 20)

Gametangium answered 15/7, 2010 at 18:14 Comment(1)
Note: your title asks for the "best practice" but your question asks for "the most efficient way". These aren't necessarily the same.Saphra
P
10

I usually recommend a design called Closure Table.

See example in my answer to What is the most efficient/elegant way to parse a flat table into a tree?

I also designed this presentation: Models for Hierarchical Data with SQL and PHP. I developed a PHP app that render a tree in 0.3 seconds, from a collection of hierarchical data with 490k nodes.

I blogged about Closure Table here: Rendering Trees with Closure Table.

I wrote a chapter about different strategies for hierarchical data in my book, SQL Antipatterns Volume 1: Avoiding the Pitfalls of Database Programming.

Prescribe answered 15/7, 2010 at 18:25 Comment(0)
S
5

For the most efficient way Quassnoi has written a series of articles on this subject.

I suggest you read the first article and adapt the examples to work with your specific table, but the crux is to make a function that can recurse over the rows you need to fetch. You probably also want the level (depth in the heirarchy) so the second article is probably also relevant too.

The other articles may be useful if you need to make other types of queries on your data. He also has an article Adjacency list vs. nested sets: MySQL in which he compares highly optimized queries for both the adjacency model and the nested set model.

Saphra answered 15/7, 2010 at 18:18 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.