• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

php+mysql不用递归实现的无限级分类实例(非递归)_PHP

php 搞代码 4年前 (2022-01-25) 17次浏览 已收录 0个评论

要实现无限级分类,递归一般是第一个也是最容易想到的,但是递归一般被认为占用资源的方法,所以很多系统是不考虑使用递归的
本文还是通过数据库的设计,用一句sql语句实现
数据库字段大概如下:

复制代码 代码如下:id 编号
fid 父分类编号
class_name 分类名
path 分类路径,以 id 为节点,组成类似 ,1,2,3,4, 这样的字符串

可以假设有如下的数据:
复制代码 代码如下:
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,

无限级分类操作代码:

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'] <strong>2本文来源gaodaima#com搞(代@码$网6</strong><pre>搞gaodaima代码

) ) – 1 );echo $space . $row [‘name’] . ”;*//** 第二种展示方法*/$space = str_repeat ( ‘——’, count ( explode ( ‘-‘, $row [‘abspath’] ) ) – 1 );$option .= ” . $space . $row [‘name’] . ‘
‘;}echo $option;exit();echo ” . $option . ”;

其中$nbs是数据库操作类,此方法简单明了!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:php+mysql不用递归实现的无限级分类实例(非递归)_PHP
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址