Sunday, September 9, 2007

Single Table Multiple Category - Subcategory:

Some time it is needed to develop unlimited categories – subcategories. Usually we solve this problem by using TREE data structure. TREE is mainly used to represent data containing a hierarchical relationship between elements, records, family tree and table of contents. So TREE is the best structure to represent category-subcategory hierarchy.

TREE Structure:
A tree is a recursive structure that usually maps an ordered set of data from an internal definition to some data space. Tree parts are often named after their contemporaries in family trees; trees contain nodes known as parent, child, and sibling. Trees are made of nodes, which can contain both data to be stored and always link to further levels in the tree. Trees are often formed from a single node known as root; alternatively, trees may be built from a set of original nodes--this is known as a forest of trees


Representing TREE in a table:



Amazing DFS:
The general idea behind a depth first search beginning at a starting node A is follows. First we examine the starting node A. Then we examine each node N along a path P which begins at A. That is we process a neighbor of A, then neighbor of (neighbor of A) and so on. After coming to the “dead end” that is, to the end of path P, we backtrack on P until we continue along another path P. And so on.

Pre order Traversal:
The first depth-first traversal method we consider is called preorder traversal. Preorder traversal is defined recursively as follows. To do a preorder traversal of a general tree:

1. Visit the root first; and then

2. Do a preorder traversal each of the sub trees of the root one-by-one in the order given.



Algorithm (DFS):


dfs(graph G)
{
list L = empty
tree T = empty
choose a starting vertex x
search(x)
while(L is not empty)
{
remove edge (v, w) from beginning of L
if w not yet visited
{

add (v, w) to T
search(w)
}
}
}

search(vertex v)
{
visit v
for each edge (v, w)
add edge (v, w) to the beginning of L
}

Example Code (PHP - mysql):

<?php

function cats_tree($id = 0,$table)

{

static $categs = array ();

static $level = 0;

$level ++;

$sql = "SELECT category_id, category_name FROM ".$table." WHERE parent = ". $id ." ORDER BY sibling_order";

$result = mysql_query($sql);

while ($row_category = mysql_fetch_assoc($result))

{

$rs[] = $row_category;

}


if (isset($rs)) {

foreach ($rs as $row) {

$categs[$row['category_id']] = str_repeat('| ', $level -1) .'|__'. $row['category_name'];

cats_tree($row['category_id'],$table);

}

}

$level --;

return $categs;

}




$conn = mysql_connect("localhost", "USER", "PASS");
mysql_select_db("DB_NAME");


echo "<pre>";
print_r(cats_tree(0,"category"));
echo "</pre>";


?>

Output:

22 comments:

Anonymous said...

really nice help :)

Anonymous said...

Awesome blog, I hadn't noticed ashiqul-islam.blogspot.com previously during my searches!
Keep up the great work!

Anonymous said...

Hi,

Thanks for sharing this link - but unfortunately it seems to be not working? Does anybody here at ashiqul-islam.blogspot.com have a mirror or another source?


Thanks,
Thomas

Anonymous said...

Drop in on us at times to buy more information and facts in the matter of Come to see us now to obtain more low-down and facts anyway [url=http://sklep-akwarystyczny-szczecin.compare.com.pl]sklep akwarystyczny szczecin[/url]

Anonymous said...

4xJhe ghd hair
vKvb cheap uggs
xWyt michael kors sale
3uBae GHD Australia
4oYsb burberry on sale
5qPvi bottes ugg
6lKmf ghd
5qKlx louis vuitton sale
1rOvp michael kors outlet
1xHpr ghd outlet
1fZlu ugg boots cheap
9kZsp cheap nfl jerseys
9dXmr michael kors bags
0eGvr ghd france
6tKsm ugg boots sale

Anonymous said...

gTpb ghd hair straightener
iRqt ugg uk
tMrg michael kors outlet
9dMrq ugg boots
1gPgr chi straightener
2oQhe michael kors purses
9eEni cheap nfl jerseys
8sRsq ghd
7cCpl north face sale
1cOxz botas ugg
3pAaa cheap ghd straighteners uk
6zHey michael kors purse
6pYyg nfl jerseys
3kRro ghd españa
8rMxn ugg sale

Anonymous said...

buy ciprofloxacin buy cipro uk
ciloxan buy
ciprofloxacin buy no prescription

Anonymous said...

[url=http://casodex-bicalutamide.webs.com/]Casdrogen
[/url] Saveprost
Bicalutamide buy
Bicalutamida

Anonymous said...

clomid false positive | clomid 50 mg - clomid drug, bodybuilding clomid

Anonymous said...

clomid steroid cycle | [url=http://ordergenericclomid.webs.com/#93525]non prescription clomid[/url] - buying clomid line, zdbm doses of clomid

Anonymous said...

euro soma for sale no prescription - buy cheap soma http://www.somanorxonline.com/#buy-cheap-soma , [url=http://www.somanorxonline.com/#cheap-carisoprodol-no-prescription ]cheap carisoprodol no prescription [/url]

Anonymous said...

This funԁs coulԁ be uѕed tο and desires filleԁ online anԁ posteԁ When
it comes to pay daу loans in most Claims thesе Ρaydaу
advance Companies can receive an Аpr interеst rates of 36%This is a really important guideline in today's housing market more bank loan wouldn't be within the loan offers you can get Unguaranteed loan never insist anyone to pledge just about any collateral contrary to the loan since these loans are collateral cost-free loansThis proceed obtain acknowledged rapidly as well as nothing nominal of the as opposed to normal financial products But Christmas adds and extra burden in people who are unemployed, it becomes a lot difficult for these phones tackle by using expenses Rather than secured mortgage you have to place your assets seeing that collateral arranged with the loan providerYou will simply should fill out a couple of electronic sorts, detailing ones financial info for agreementAnother common issue for online doctorate students is definitely the lack of finance That is a city of deluxe life, and also living existence the way you desire is always somewhat expensiveThis is for many these kinds of borrowers that do not have a great credit score these kinds of sites that fear rejection through auto loan creditorsCollege Pell Grants: Issues to consider Besides Fiscal Need

Stop by my blog post: online payday Loans

Anonymous said...

http://ωww.netwοгk-lоanѕ.
cο.uk

My page quick loans

Anonymous said...

http://www.network-loanѕ.cο.uk

Feel frеe to ѵisіt my ωeblog .
.. Www.vpaydayloansuk.Co.uk

Anonymous said...

Hi, cheap soma - order carisoprodol http://www.ayuhyoga.com/, [url=http://www.ayuhyoga.com/]order soma[/url]

Anonymous said...

12, Maxalt Online - maxalt online pharmacy http://www.maxaltrxonline.net/, [url=http://www.maxaltrxonline.net/]Buy Rizatriptan [/url]

Anonymous said...

12, Price of Lamisil - generic terbinafine http://www.lamisilfast24.net/, [url=http://www.lamisilfast24.net/] Lamisil Sale [/url]

Anonymous said...

Thanks for your personal marvelous posting! I seriously enjoyed reading it, you may be a
great author. I will be sure to bookmark your
blog and definitely will come back in the future. I want to encourage continue your great writing,
have a nice holiday weekend!

My site - uk payday loans no credit check

Anonymous said...

Truly beneficial look frontward to coming back again.


Feel free to visit my page: instant payday loans

Anonymous said...

This is a great tip particularly to those fresh to the
blogosphere. Brief but very accurate information… Appreciate your sharing this one.
A must read post!

Here is my weblog; payday loans online uk

Anonymous said...

[url=http://www.vip1michaelkorsoutlet.org]Michael Kors Outlet[/url] Have dinner at Mobil Two-Star Jaleo (480 7th Street NW)

[url=http://www.mislouboutinsaleuk.co.uk]Christian Louboutin UK[/url]Here's where to get jaw-dropping deals on designer footwear

[url=http://www.getfreerunaustralia.org]Nike Shoes Australia[/url]Be honest

[url=http://www.vipnikenewzealand.info]Cheap Nike Shoes[/url] Many parents regard it necessary for kids to wear shoes

[url=http://www.upnikepascherfr.info]Nike Dunk[/url] In a perfect appearance shoes , you can show your elegance and grace fully

tysoo said...

have a peek at this web-sitetry here have a peek herelinked here my companyview