php专区

 首页 > php专区 > PHP应用 > 常用功能 > php 无限分类实现原理详解 - php高级应用

php 无限分类实现原理详解 - php高级应用

分享到:
【字体:
导读:
          在php中无限分类是我们在实际开发中经常用到的一种数据结构,一般我们称之为树形结构,像我网站的分类有php入门,正则等等分类,这种是二级不是无限级了,如果是无限级就可以在子类下加...

php 无限分类实现原理详解

在php中无限分类是我们在实际开发中经常用到的一种数据结构,一般我们称之为树形结构,像我网站的分类有php入门,正则等等分类,这种是二级不是无限级了,如果是无限级就可以在子类下加子类了.

我们先来看我实现无限分类的具体过程.

题设:类似淘宝的商品分类,可以在任意分类设置其子类.

一、创建`type`数据表,代码如下:

  1. `id` 自增长 
  2.  
  3. `fid` int(11) 默认(0) ,父节点id 
  4.  
  5. `namevarchar(50),分类名称 
  6.  
  7. CREATE TABLE `type` ( 
  8.   `id` int(11) NOT NULL AUTO_INCREMENT, 
  9.   `fid` int(11) NOT NULL DEFAULT '0'
  10.   `namevarchar(50) NOT NULL
  11.   PRIMARY KEY (`id`) 

二、添加,我们先添加几个顶级分类,代码如下:

  1. INSERT INTO `type` (`id`, `fid`, `name`) VALUES (NULL'0''手机'); 
  2. INSERT INTO `type` (`id`, `fid`, `name`) VALUES (NULL'0''电脑'); 
  3. INSERT INTO `type` (`id`, `fid`, `name`) VALUES (NULL'0''鞋子'); 
  4. INSERT INTO `type` (`id`, `fid`, `name`) VALUES (NULL'0''衣服');这里fid=0是代表顶级分类 

接着我们为{电脑}添加几个个子分类,代码如下:

INSERT INTO `type` (`id`, `fid`, `name`) VALUES (NULL, '2', '台式'), (NULL, '2', '笔记本');

这里fid=2,2这个id是分类{电脑}的id,如果是添加{鞋子}的子分类则fid=3,同理我们为{笔记本}添加子分类则fid=6,代码如下:

INSERT INTO `type` (`id`, `fid`, `name`) VALUES (NULL, '6', 'ausu'), (NULL, '6', 'hp');

三、删除,如果我们想删除{笔记本}这个分类,很简单:

DELETE FROM `type` WHERE `id`=6{笔记本}的子分类我们也要记得做相应的处理

代码如下:

  1. function del($fid) { 
  2.     $sql="SELECT * FROM `type` WHERE `fid`=$fid"
  3.     $rs=mysql_query($sql); 
  4.      
  5.     for ($i = 0; $i < count($rs); $i++) { 
  6.         $sql="DELETE FROM `type` WHERE `id`={$rs[$i]['id']}"
  7.         mysql_query($sql); 
  8.          
  9.         del($rs['id']);//递归 
  10.     } 
  11. del(6);//执行操作这里你也许你会疑惑为什么那么麻烦用递归,而不是直接这样删除 

DELETE FROM `type` WHERE `fid`=6这样我们不就可以直接删除{ausu}、{hp}?但是假设{ausu}有一个子分类{a1},{a1}也有一个子分类{a2},如果不用递归我们就无法彻底删除数据.

四、查找

1.查找{电脑}的子分类

SELECT * FROM `type` WHERE `fid`=22.查找{电脑}的所有子分类

代码如下:

  1. function sel($fid) { 
  2.     $sql="SELECT * FROM `type` WHERE `fid`=$fid"
  3.     $rs=mysql_query($sql); 
  4.      
  5.     for ($i = 0; $i < count($rs); $i++) { 
  6.         echo $rs[$i]['name']; 
  7.          
  8.         sel($rs[$i]['id']);//递归 
  9.     } 
  10. sel(2); 

五、实际数据应用

在数据表添加一个字段`tid`,字段值为记录所属分类`type`表的id,必须是id不能是name,因为name的值可能会改变.

例如查询属于{电脑}分类的商品,代码如下:

SELECT * FROM `goods` WHERE `tid`=2

下面再看个实例,直接操作数组,代码如下:

  1. $rows = array
  2.     array
  3.         'id' => 1, 
  4.         'name' => 'dev'
  5.         'parentid' => 0 
  6.     ), 
  7.     array
  8.         'id' => 2, 
  9.         'name' => 'php'
  10.         'parentid' => 1 
  11.     ), 
  12.     array
  13.         'id' => 3, 
  14.         'name' => 'smarty'
  15.         'parentid' => 2 
  16.     ), 
  17.     array
  18.         'id' => 4, 
  19.         'name' => 'life'
  20.         'parentid' => 0 
  21.     ), 
  22.     array
  23.         'id' => 5, 
  24.         'name' => 'pdo'
  25.         'parentid' => 2 
  26.     ), 
  27.     array
  28.         'id' => 6, 
  29.         'name' => 'pdo-mysql'
  30.         'parentid' => 5 
  31.     ), 
  32.     array
  33.         'id' => 7, 
  34.         'name' => 'java'
  35.         'parentid' => 1 
  36.     ) 
  37. ); 
  38.  
  39. // 72648 
  40. // 84072 
  41.  
  42. function findChild(&$arr,$id){ 
  43.    
  44.     $childs=array(); 
  45.      foreach ($arr as $k => $v){ 
  46.          if($v['parentid']== $id){ 
  47.               $childs[]=$v
  48.     
  49.          } 
  50.          
  51.     } 
  52.        
  53.     return $childs
  54.      
  55.      
  56. function build_tree($root_id){ 
  57.     global $rows
  58.     $childs=findChild($rows,$root_id); 
  59.     if(emptyempty($childs)){ 
  60.         return null; 
  61.     } 
  62.    foreach ($childs as $k => $v){ 
  63.        $rescurTree=build_tree($v[id]); 
  64.        if( null !=   $rescurTree){  
  65.        $childs[$k]['childs']=$rescurTree
  66.        } 
  67.    } 
  68.     return $childs
  69. $tree=build_tree(0); 
  70. echo memory_get_usage(); 
  71. print_r($tree); 
  72. ?> 

我自己用的可以做那种下拉效果并带有级数的效果,代码如下:

  1. function dafenglei_select($m,$id$fenlei ){ 
  2.  global $menu
  3.  $n = str_pad('',$m,'-',STR_PAD_RIGHT); 
  4.  $n = str_replace("-","   ",$n); 
  5.  for($i=0;$i<count($fenlei);$i++){ 
  6.  
  7.   if($fenlei[$i]['classid']==$id){ 
  8.      $menu .= "".$fenlei[$i]['id']."">".$n."|—".$fenlei[$i]['name']."n";  
  9.    } 
  10.    $this->dafenglei_select($m+1,$fenlei[$i]['id'], $fenlei ); 
  11.   }  
  12.  } 
  13.  return $menu
  14.  
  15. dafenglei_select(0,0, $fenlei ); 

$fenlei 无限分类数组 $id是选择从哪个分类开始写0代表顶级开始分,只要把数组放进去就可以分了.

分享到:
php intval() 小数时安全漏洞分析 - php...
php intval() 小数时安全漏洞分析 本文章先来介绍了php intval简单用法,它可以把字符,数字,小数转换灰数字型数据,但在转换时会出现一些问题如小数1.1就会转换成1,下面看实例. 一、变量转成整数类型. 语法:int intval(mixed var, int [base]); 返回值:整数 函数种类:PHP 系统功能 内容说...
php 全面禁止浏览器缓存页面内容详解 - p...
php 全面禁止浏览器缓存页面内容详解 本文章来给大家介绍如何在php中利用相关保代码来禁止浏览器缓存页面内容,在php中我们只要使用header命令带一些参数即可实例。 代码如下: header("Cache-Control:no-cache,must-revalidate,no-store"); //这个no-store加了之后,Firefox下有效  ...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……