PHP實(shí)現(xiàn)無(wú)限分類(lèi)的實(shí)現(xiàn)方法
無(wú)限級(jí)分類(lèi)是一種設(shè)計(jì)技巧,在開(kāi)發(fā)中經(jīng)常使用,例如:網(wǎng)站目錄、部門(mén)結(jié)構(gòu)、文章分類(lèi)。筆者覺(jué)得它在對(duì)于設(shè)計(jì)表的層級(jí)結(jié)構(gòu)上面發(fā)揮很大的作用,比如大家在一些平臺(tái)上面,
填寫(xiě)邀請(qǐng)人,它就是一種上下級(jí)的關(guān)系,上級(jí)會(huì)有多個(gè)下級(jí),下級(jí)又會(huì)有自己的分支,大多數(shù)都是利用遞歸的思想去實(shí)現(xiàn)。話(huà)不多說(shuō),首先來(lái)溫故一下遞歸的實(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);
}
}
```
一、無(wú)限分類(lèi)實(shí)現(xiàn):
1、表設(shè)計(jì)設(shè)置父id 頂級(jí)父id設(shè)為0 建立族譜樹(shù);每一個(gè)分類(lèi)都需記錄它的父級(jí)id。( pid=0 代表頂級(jí) )
id pid catename cateorder createtime ( 主鍵id,父id,分類(lèi)name,分類(lèi)排序,創(chuàng)建時(shí)間)
舉例:網(wǎng)站的分類(lèi)目錄結(jié)構(gòu);餐飲的分類(lèi)結(jié)構(gòu);評(píng)論的結(jié)構(gòu)
2、全路徑無(wú)限分類(lèi)(以一個(gè)字段將所有父級(jí)id按順序記錄下來(lái))
id path catename cateorder createtime ( 主鍵id,逗號(hào)分隔的順序排列父id,分類(lèi)name,分類(lèi)排序,創(chuàng)建時(shí)間)
優(yōu)缺點(diǎn):
全路徑查詢(xún)方便;增加,移動(dòng)分類(lèi)時(shí)數(shù)據(jù)維護(hù)稍顯復(fù)雜;
二、舉例實(shí)現(xiàn)(網(wǎng)站目錄):
分類(lèi)表:
```
#父級(jí)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,'美女寫(xiě)真',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,'美女寫(xiě)真',null,'2016-11-01');
```
獲取圖片所在的目錄路徑:
```
#父級(jí)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,'美女寫(xiě)真',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,'美女寫(xiě)真',null,'2016-11-01');
```
*注意點(diǎn):
移動(dòng)分類(lèi)不能移到自己及其子類(lèi)下面;刪除分類(lèi) (只能刪除最底層的分類(lèi),及不含子類(lèi)的分類(lèi);換言之,只能從最底層刪起).
思考圖片類(lèi)型下所有的圖片分類(lèi)?
```
#pid 父級(jí)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;
}
```
此類(lèi)方法比較適用于查詢(xún)所在父分類(lèi)下所有的書(shū)籍、文章。。。當(dāng)然,全路徑可以直接獲取,就不再此提出了。
實(shí)際操作中,我們可以根據(jù)實(shí)際情況設(shè)計(jì)合理的表結(jié)構(gòu)。
舉個(gè)實(shí)例,連鎖門(mén)店實(shí)現(xiàn)商品的管理,門(mén)店的賬戶(hù)設(shè)置就會(huì)存在上下級(jí)關(guān)系,根據(jù)代理點(diǎn)的分區(qū)可能存在這種下級(jí)擁有自己下級(jí),那么采用這種無(wú)限分類(lèi)的方法就比較靈活面對(duì)這種關(guān)系體系,只需設(shè)定每個(gè)賬戶(hù)等級(jí),就能對(duì)不同的門(mén)店設(shè)定權(quán)限分配。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- PHP無(wú)限分類(lèi)的類(lèi)
- PHP 無(wú)限分類(lèi)三種方式 非函數(shù)的遞歸調(diào)用!
- php 無(wú)限分類(lèi)的樹(shù)類(lèi)代碼
- PHP無(wú)限分類(lèi)(樹(shù)形類(lèi))
- php無(wú)限分類(lèi)且支持輸出樹(shù)狀圖的詳細(xì)介紹
- php遞歸方法實(shí)現(xiàn)無(wú)限分類(lèi)實(shí)例代碼
- PHP無(wú)限分類(lèi)代碼,支持?jǐn)?shù)組格式化、直接輸出菜單兩種方式
- 帖幾個(gè)PHP的無(wú)限分類(lèi)實(shí)現(xiàn)想法~
- php 進(jìn)階:實(shí)現(xiàn)無(wú)限分類(lèi)
相關(guān)文章
Codeigniter中mkdir創(chuàng)建目錄遇到權(quán)限問(wèn)題和解決方法
這篇文章主要介紹了Codeigniter中mkdir創(chuàng)建目錄遇到權(quán)限問(wèn)題和解決方法,需要的朋友可以參考下2014-07-07
PHP代碼判斷設(shè)備是手機(jī)還是平板電腦(兩種方法)
隨著互聯(lián)網(wǎng)移動(dòng)設(shè)備的普及,很多網(wǎng)站都兼容手機(jī)端瀏覽,為了更好的讓網(wǎng)頁(yè)在手機(jī)端顯示,我們都選擇了使用CSS媒體查詢(xún)制作響應(yīng)式模版。本文給大家介紹PHP代碼判斷設(shè)備是手機(jī)還是平板電腦(兩種方法),感興趣的朋友一起學(xué)習(xí)吧2015-10-10
Yii框架中 find findAll 查找出制定的字段的方法對(duì)比
在yii框架中可以使用映射類(lèi)的find方法取出一條數(shù)據(jù)或者用findall方法取出數(shù)條數(shù)據(jù)來(lái),那么如何按照所需條件來(lái)取數(shù)據(jù)呢,主要用到了CDbCriteria這個(gè)類(lèi),這個(gè)類(lèi)是yii自帶的操作數(shù)據(jù)庫(kù)的支持類(lèi)2014-09-09

