首先建立分类信息表:

  1. CREATE TABLE IF NOT EXISTS `category` (
  2. `categoryId` smallint(5) unsigned NOT NULL AUTO_INCREMENT,
  3. `parentId` smallint(5) unsigned NOT NULL DEFAULT '0',
  4. `categoryName` varchar(50) NOT NULL,
  5. PRIMARY KEY (`categoryId`)
  6. )  ;

插入若干数据:

  1. INSERT INTO `category` (`categoryId`, `parentId`, `categoryName`) VALUES
  2. (1, 0, 'php'),
  3. (2, 0, 'java'),
  4. (3, 0, 'c/c++'),
  5. (4, 1, 'php基础'),
  6. (5, 1, 'php开源资料'),
  7. (6, 1, 'php框架'),
  8. (7, 2, 'java Se'),
  9. (8, 2, 'java EE'),
  10. (9, 2, 'java Me'),
  11. (10, 3, 'c/c++基础编程'),
  12. (11, 3, 'c/c++系统开发'),
  13. (12, 3, 'c嵌入式编程'),
  14. (13, 3, 'c++应用开发'),
  15. (14, 13, 'c++桌面应用开发'),
  16. (15, 13, 'c++游戏开发');

下面是php代码:

  1. <?php
  2. /*
  1. php无限极分类
  1. */
  2. //获取某分类的直接子分类
  3. function getSons($categorys,$catId=0){
  4. $sons=array();
  5. foreach($categorys as $item){
  6. if($item['parentId']==$catId)
  7. $sons[]=$item;
  8. }
  9. return $sons;
  10. }
  11. //获取某个分类的所有子分类
  12. function getSubs($categorys,$catId=0,$level=1){
  13. $subs=array();
  14. foreach($categorys as $item){
  15. if($item['parentId']==$catId){
  16. $item['level']=$level;
  17. $subs[]=$item;
  18. $subs=array_merge($subs,getSubs($categorys,$item['categoryId'],$level+1));
  19. }
  20. }
  21. return $subs;
  22. }
  23. //获取某个分类的所有父分类
  24. //方法一,递归
  25. function getParents($categorys,$catId){
  26. $tree=array();
  27. foreach($categorys as $item){
  28. if($item['categoryId']==$catId){
  29. if($item['parentId']>0)
  30. $tree=array_merge($tree,getParents($categorys,$item['parentId']));
  31. $tree[]=$item;
  32. break;
  33. }
  34. }
  35. return $tree;
  36. }
  37. //方法二,迭代
  38. function getParents2($categorys,$catId){
  39. $tree=array();
  40. while($catId != 0){
  41. foreach($categorys as $item){
  42. if($item['categoryId']==$catId){
  43. $tree[]=$item;
  44. $catId=$item['parentId'];
  45. break;
  46. }
  47. }
  48. }
  49. return $tree;
  50. }
  51. //测试 部分
  52. $pdo=new PDO('mysql:host=localhost;dbname=test','root','8888');
  53. $stmt=$pdo->query("select * from category order by categoryId");
  54. $categorys=$stmt->fetchAll(PDO::FETCH_ASSOC);
  55. $result=getSons($categorys,1);
  56. foreach($result as $item)
  57. echo $item['categoryName'].'<br>';
  58. echo '<hr>';
  59. $result=getSubs($categorys,0);
  60. foreach($result as $item)
  61. echo str_repeat('  ',$item['level']).$item['categoryName'].'<br>';
  62. echo '<hr>';
  63. $result=getParents($categorys,7);
  64. foreach($result as $item)
  65. echo $item['categoryName'].' >> ';
  66. echo '<hr>';
  67. $result=getParents2($categorys,15);
  68. foreach($result as $item)
  69. echo $item['categoryName'].' >> ';
  70. ?>

下面是运行的结果:

文章来源:http://blog.csdn.net/kankan231/article/details/8462349

php之无限极分类的更多相关文章

  1. php无限极分类以及递归(thinkphp)

    php无限极分类: 无限极分类重点在于表的设计: 1在model中: class CatModel extends Model{ protected $cat = array(); public fu ...

  2. js实现无限极分类

    转载注明出处!!! 转载注明出处!!! 转载注明出处!!! 因为要实现部门通讯录,后台传来的数据是直接从数据库里拿的部门表,所以没有层级分类,只有parentId表示从属关系,所以分类的事情就交给我来 ...

  3. C#无限极分类树-创建-排序-读取 用Asp.Net Core+EF实现之方法二:加入缓存机制

    在上一篇文章中我用递归方法实现了管理菜单,在上一节我也提到要考虑用缓存,也算是学习一下.Net Core的缓存机制. 关于.Net Core的缓存,官方有三种实现: 1.In Memory Cachi ...

  4. PHP无限极分类

      当你学习php无限极分类的时候,大家都觉得一个字“难”我也觉得很难,所以,现在都还在看,因为工作要用到,所以,就必须得研究研究. 到网上一搜php无限极分类,很多,但好多都是一个,并且,写的很乱, ...

  5. PHP无限极分类,多种方法|很简单,这里说的很详细,其它地方说的很不好懂

    当你学习php无限极分类的时候,大家都觉得一个字"难"我也觉得很难,所以,现在都还在看,因为工作要用到,所以,就必须得研究研究.   到网上一搜php无限极分类,很多,但好多都是一 ...

  6. C#无限极分类树-创建-排序-读取 用Asp.Net Core+EF实现

    今天做一个管理后台菜单,想着要用无限极分类,记得园子里还是什么地方见过这种写法,可今天找了半天也没找到,没办法静下心来自己写了: 首先创建节点类(我给它取名:AdminUserTree): /// & ...

  7. 谈一次php无限极分类的案例

    作者:白狼 出处:http://www.manks.top/php_tree_deep.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追 ...

  8. PHP无限极分类生成树方法,无限分级

    你还在用浪费时间又浪费内存的递归遍历无限极分类吗,看了该篇文章,我觉得你应该换换了.这是我在OSChina上看到的一段非常精简的PHP无限极分类生成树方法,巧在引用,整理分享了. function g ...

  9. PHP无限极分类实现

    简单版的PHP生成无限极分类代码.其中包括了数据库设计.以及输出分类HTML代码. SQL代码 CREATE TABLE `district` ( `id` int(10) unsigned NOT ...

随机推荐

  1. java并发编程参考资料

    1.java编程思想 2.java并发编程实战 3.java并发编程的艺术 4.http://www.infoq.com/cn/author/%E7%A8%8B%E6%99%93%E6%98%8E#文 ...

  2. Android自定义View (二) 进阶

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/24300125 继续自定义View之旅,前面已经介绍过一个自定义View的基础的例 ...

  3. android 修改framework下资源文件后如何编译

    在framework/base/core/res/res 下添加资源文件后需要先编译资源 然后编译framework 才可正常引用 进入项目根目录 cd frameworks/base/core/re ...

  4. php进制转换函数

    1 十进制(decimal system)转换函数 ① 十进制转二进制 string  decbin(int number). 参数为一个十进制整型数字,不是整型数字会自动转为整型数字,如'3'转为3 ...

  5. Query Designer中的特征限制(Characteristic Restrictions)、缺省值(Default Values)、自由特性(Free Characteristics)

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  6. css取消input、select默认样式(手机端)

    IOS端: background-color:transparent; border-color:transparent; andorid端: 仅仅使用上面的代码还不够,可以发现select框在某些浏 ...

  7. mac 安装 nginx 环境

    1.brew search nginx 2.brew install nginx 启动nginx ,sudo nginx ;访问localhost:8080 发现已出现nginx的欢迎页面了. 备注: ...

  8. OSG开发概览

    1 OSG基础知识 Ø OSG是Open Scene Graphic 的缩写,OSG于1997年诞生于以为滑翔机爱好者之手,Don burns  为了对滑翔机的飞行进行模拟,对openGL的库进行了封 ...

  9. js 获取iframe中的元素

    今天要修改编辑器插件中的元素遇到的问题 jquery 在父窗口中获取iframe中的元素 1.Js代码 格式:$("#iframe的ID").contents().find(&qu ...

  10. hdu4511小明系列故事——女友的考验(ac自动机+最短路)

    链接 预处理出来任意两点的距离,然后可以顺着trie树中的节点走,不能走到不合法的地方,另开一维表示走到了哪里,依次来更新. 注意判断一下起点是不是合法. #include <iostream& ...