|
要實(shí)現(xiàn)無(wú)限級(jí)分類(lèi),遞歸一般是第一個(gè)也是最容易想到的,但是遞歸一般被認(rèn)為占用資源的方法,所以很多系統(tǒng)是不考慮使用遞歸的
本文還是通過(guò)數(shù)據(jù)庫(kù)的設(shè)計(jì),用一句sql語(yǔ)句實(shí)現(xiàn)
數(shù)據(jù)庫(kù)字段大概如下:
復(fù)制代碼 代碼如下:id 編號(hào)
fid 父分類(lèi)編號(hào)
class_name 分類(lèi)名
path 分類(lèi)路徑,以 id 為節(jié)點(diǎn),組成類(lèi)似 ,1,2,3,4, 這樣的字符串
可以假設(shè)有如下的數(shù)據(jù):
復(fù)制代碼 代碼如下:
id fid class_name path
1 0 分類(lèi)1 , 1,
2 0 分類(lèi)2 , 2,
3 1 分類(lèi)1-1 , 1,3,
4 1 分類(lèi)1-2 , 1,4,
5 2 分類(lèi)2-1 , 2,5,
6 4 分類(lèi)1-2-1 , 1,4,6,
無(wú)限級(jí)分類(lèi)操作代碼:
<?php $sql=”SELECT * FROM tree order by path”; $result=$nbs->Query($sql); while($rows=$nbs->fetch_array($result)){ if(substr_count($rows['path'],',')>2){ for($i=0;$i<(substr_count($rows['path'],',')-2);$i++) echo ‘ ‘; } echo $rows['class_name'].'<br>'; } ?> $conn = mysql_connect ( 'localhost', 'root', 'root' );mysql_select_db ( 'wanggou123', $conn );mysql_query ( 'set names UTF8' );$sql = "select id,concat(catpath,'-',id) as abspath,name from category order by abspath"; $query = mysql_query ( $sql );while ( $row=mysql_fetch_array($query)) { /** * 第一種展示方法*//*$space = str_repeat ( ' ', count ( explode ( '-', $row ['abspath'] ) ) - 1 );echo $space . $row ['name'] . '';*//** 第二種展示方法*/$space = str_repeat ( '――', count ( explode ( '-', $row ['abspath'] ) ) - 1 );$option .= '' . $space . $row ['name'] . '<Br>';}echo $option;exit();echo '<select name="opt">' . $option . '</select>';
其中$nbs是數(shù)據(jù)庫(kù)操作類(lèi),此方法簡(jiǎn)單明了!
php技術(shù):php+mysql不用遞歸實(shí)現(xiàn)的無(wú)限級(jí)分類(lèi)實(shí)例(非遞歸),轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。