欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP實(shí)現(xiàn)無限分類的實(shí)現(xiàn)方法

 更新時(shí)間:2016年11月14日 08:22:18   作者:小毅、  
無限級分類是一種設(shè)計(jì)技巧,在開發(fā)中經(jīng)常使用,本篇文章主要介紹PHP實(shí)現(xiàn)無限分類的實(shí)現(xiàn)方法,有需要的可以了解一下。

無限級分類是一種設(shè)計(jì)技巧,在開發(fā)中經(jīng)常使用,例如:網(wǎng)站目錄、部門結(jié)構(gòu)、文章分類。筆者覺得它在對于設(shè)計(jì)表的層級結(jié)構(gòu)上面發(fā)揮很大的作用,比如大家在一些平臺上面,

填寫邀請人,它就是一種上下級的關(guān)系,上級會有多個(gè)下級,下級又會有自己的分支,大多數(shù)都是利用遞歸的思想去實(shí)現(xiàn)。話不多說,首先來溫故一下遞歸的實(shí)現(xiàn)

遞歸(程序調(diào)用自身的編程技巧):

1、$_GLOBALS[result]

2、static $result

3、參數(shù)引用&

舉例:遍歷1-10

```
$i=0;
function deeploop( $i ){
  global $i;
  $i++;
  echo $i;
  if( $i<10 ){
    deeploop($i);
  }

}

function deeploop( ){
  static $i=0;
  $i++;
  echo $i;
  if( $i<10 ){
    deeploop($i);
  }

}


function deeploop( &$i=0 ){
  $i++;
  echo $i;
  if( $i<10 ){
    deeploop($i);
  }

}

```

一、無限分類實(shí)現(xiàn):

1、表設(shè)計(jì)設(shè)置父id 頂級父id設(shè)為0   建立族譜樹;每一個(gè)分類都需記錄它的父級id。( pid=0 代表頂級 )   

id pid catename cateorder createtime  ( 主鍵id,父id,分類name,分類排序,創(chuàng)建時(shí)間)

舉例:網(wǎng)站的分類目錄結(jié)構(gòu);餐飲的分類結(jié)構(gòu);評論的結(jié)構(gòu)

 2、全路徑無限分類(以一個(gè)字段將所有父級id按順序記錄下來)

 id path catename cateorder createtime  ( 主鍵id,逗號分隔的順序排列父id,分類name,分類排序,創(chuàng)建時(shí)間)

優(yōu)缺點(diǎn):

全路徑查詢方便;增加,移動(dòng)分類時(shí)數(shù)據(jù)維護(hù)稍顯復(fù)雜;

二、舉例實(shí)現(xiàn)(網(wǎng)站目錄):

分類表:

  ```
    #父級Id遞歸法
    CREATE TABLE `deepcate`(
      `id` int(11) NOT NULL AUTO_INCREMENT PRIMARY KEY,
      `pid` int(11) NOT NULL DEFAULT 0,
      `catename` char(25) NOT NULL,
      `cateorder` int(6) ,
      `createtime` date
    )ENGINE=INNODB default CHARSET=utf8;
    
    
    //數(shù)據(jù)
    INSERT INTO `deepcate` VALUES(1,0,'圖片',null,'2016-11-01'),
                  ( 2,1,'美女',null,'2016-11-01'),
                  ( 3,1,'新聞',null,'2016-11-01'),
                  ( 4,2,'足球?qū)氊?,null,'2016-11-01'),
                  ( 5,2,'日韓明星',null,'2016-11-01'),
                  ( 6,5,'美女寫真',null,'2016-11-01');
                  
    #全路徑
    CREATE TABLE `qljcate` (
      `id` int(11) NOT NULL,
      `path` char(255) ,
      `catename` char(25) NOT NULL,
      `cateorder` int(6),
      `createtime` date
    )ENGINE=INNODB default CHARSET=utf8;
    
    INSERT INTO `qljcate` VALUES( 1,null,'圖片',null,'2016-11-01'),
                  ( 2,1,'美女圖片',null,'2016-11-01'),
              ( 3,1,2,'足球?qū)氊?,null,'2016-11-01'),
                  ( 4,1,2,'日韓明星',null,'2016-11-01'),
                  ( 5,1,2,4,'美女寫真',null,'2016-11-01');
  ```

    獲取圖片所在的目錄路徑:
  

  ```
    #父級Id遞歸法
    CREATE TABLE `deepcate`(
      `id` int(11) NOT NULL AUTO_INCREMENT PRIMARY KEY,
      `pid` int(11) NOT NULL DEFAULT 0,
      `catename` char(25) NOT NULL,
      `cateorder` int(6) ,
      `createtime` date
    )ENGINE=INNODB default CHARSET=utf8;
    
    
    //數(shù)據(jù)
    INSERT INTO `deepcate` VALUES(1,0,'圖片',null,'2016-11-01'),
                  ( 2,1,'美女',null,'2016-11-01'),
                  ( 3,1,'新聞',null,'2016-11-01'),
                  ( 4,2,'足球?qū)氊?,null,'2016-11-01'),
                  ( 5,2,'日韓明星',null,'2016-11-01'),
                  ( 6,5,'美女寫真',null,'2016-11-01');
                  
    #全路徑
    CREATE TABLE `qljcate` (
      `id` int(11) NOT NULL,
      `path` char(255) ,
      `catename` char(25) NOT NULL,
      `cateorder` int(6),
      `createtime` date
    )ENGINE=INNODB default CHARSET=utf8;
    
    INSERT INTO `qljcate` VALUES( 1,null,'圖片',null,'2016-11-01'),
                  ( 2,1,'美女圖片',null,'2016-11-01'),
              ( 3,1,2,'足球?qū)氊?,null,'2016-11-01'),
                  ( 4,1,2,'日韓明星',null,'2016-11-01'),
                  ( 5,1,2,4,'美女寫真',null,'2016-11-01');
  ```

*注意點(diǎn):

移動(dòng)分類不能移到自己及其子類下面;刪除分類 (只能刪除最底層的分類,及不含子類的分類;換言之,只能從最底層刪起).

   思考圖片類型下所有的圖片分類? 

```
  #pid 父級id實(shí)現(xiàn)法
  function GetAllcate( $id,&$result=array() ){
    $sql = "SELECT * FROM deepcate WHERE pid in ({$id})";
    $query = mysql_query( $sql );
    $row = mysql_fetch_assoc( $query );
    if( mysql_num_rows($row)>0 )
    {
      $idlist = array();
      while( $row ){
        $result[] = $row;
        $idlist[] = $row['id']; 
      }
      $id = implode(',',$idlist);
      GetAllcate( $id,$result );
    
    }
    
    $result = array_unique( $result );
    return $result;
  }
  ```

此類方法比較適用于查詢所在父分類下所有的書籍、文章。。。當(dāng)然,全路徑可以直接獲取,就不再此提出了。

實(shí)際操作中,我們可以根據(jù)實(shí)際情況設(shè)計(jì)合理的表結(jié)構(gòu)。

舉個(gè)實(shí)例,連鎖門店實(shí)現(xiàn)商品的管理,門店的賬戶設(shè)置就會存在上下級關(guān)系,根據(jù)代理點(diǎn)的分區(qū)可能存在這種下級擁有自己下級,那么采用這種無限分類的方法就比較靈活面對這種關(guān)系體系,只需設(shè)定每個(gè)賬戶等級,就能對不同的門店設(shè)定權(quán)限分配。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論