php+mysql不用遞歸實現(xiàn)的無限級分類實例(非遞歸)
更新時間:2014年07月08日 10:29:20 投稿:junjie
這篇文章主要介紹了php+mysql不用遞歸實現(xiàn)的無限級分類實例,重點在不使用遞歸,需要的朋友可以參考下
要實現(xiàn)無限級分類,遞歸一般是第一個也是最容易想到的,但是遞歸一般被認為占用資源的方法,所以很多系統(tǒng)是不考慮使用遞歸的
本文還是通過數(shù)據(jù)庫的設計,用一句sql語句實現(xiàn)
數(shù)據(jù)庫字段大概如下:
復制代碼 代碼如下:
id 編號
fid 父分類編號
class_name 分類名
path 分類路徑,以 id 為節(jié)點,組成類似 ,1,2,3,4, 這樣的字符串
fid 父分類編號
class_name 分類名
path 分類路徑,以 id 為節(jié)點,組成類似 ,1,2,3,4, 這樣的字符串
可以假設有如下的數(shù)據(jù):
復制代碼 代碼如下:
id fid class_name path
1 0 分類1 , 1,
2 0 分類2 , 2,
3 1 分類1-1 , 1,3,
4 1 分類1-2 , 1,4,
5 2 分類2-1 , 2,5,
6 4 分類1-2-1 , 1,4,6,
無限級分類操作代碼:
<?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ù)庫操作類,此方法簡單明了!
相關文章
Laravel 自動生成驗證的實例講解:login / logout
今天小編就為大家分享一篇Laravel 自動生成驗證的實例分析:login / logout,具有好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10php實現(xiàn)微信企業(yè)轉(zhuǎn)賬功能
這篇文章主要為大家詳細介紹了php實現(xiàn)微信企業(yè)轉(zhuǎn)賬功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-10-10