本文還是通過數(shù)據(jù)庫的設計,用一句sql語句實現(xiàn)
數(shù)據(jù)庫字段大概如下:復制代碼 代碼如下:id 編號 " /> 97天天综合网,欧美精品videos,欧美国内亚洲

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

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, 這樣的字符串

可以假設有如下的數(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ù)庫操作類,此方法簡單明了!

php技術php+mysql不用遞歸實現(xiàn)的無限級分類實例(非遞歸),轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 九龙县| 白银市| 太和县| 额济纳旗| 罗平县| 双江| 客服| 乌兰浩特市| 孙吴县| 六安市| 松潘县| 西宁市| 大英县| 依兰县| 沅陵县| 西青区| 沂水县| 湖州市| 喜德县| 康乐县| 澎湖县| 靖边县| 稷山县| 邓州市| 石狮市| 上虞市| 图片| 庄浪县| 慈利县| 山东省| 壶关县| 北碚区| 乐东| 饶河县| 夏邑县| 邛崃市| 城固县| 阿拉善右旗| 乃东县| 山丹县| 南部县|