一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

基于php無限分類的深入理解

無限分類是實際開發中經常用到的一種數據結構,一般我們稱之為樹形結構。
題設:類似淘寶的商品分類,可以在任意分類設置其子類。
 
一、創建`type`數據表
`id` 自增長
`fid` int(11) 默認(0) ,父節點id
`name` varchar(50),分類名稱
復制代碼 代碼如下:
CREATE TABLE `type` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `fid` int(11) NOT NULL DEFAULT '0',
  `name` varchar(50) NOT NULL,
  PRIMARY KEY (`id`)
)

二、添加
我們先添加幾個頂級分類
復制代碼 代碼如下:
INSERT INTO `type` (`id`, `fid`, `name`) VALUES (NULL, '0', '手機');
INSERT INTO `type` (`id`, `fid`, `name`) VALUES (NULL, '0', '電腦');
INSERT INTO `type` (`id`, `fid`, `name`) VALUES (NULL, '0', '鞋子');
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

{筆記本}的子分類我們也要記得做相應的處理
復制代碼 代碼如下:
function del($fid) {
    $sql="SELECT * FROM `type` WHERE `fid`=$fid";
    $rs=mysql_query($sql);

    for ($i = 0; $i < count($rs); $i++) {
        $sql="DELETE FROM `type` WHERE `id`={$rs[$i]['id']}";
        mysql_query($sql);

        del($rs['id']);//遞歸
    }
}
del(6);//執行操作

這里你也許你會疑惑為什么那么麻煩用遞歸,而不是直接這樣刪除
復制代碼 代碼如下:
DELETE FROM `type` WHERE `fid`=6

這樣我們不就可以直接刪除{ausu}、{hp}?但是假設{ausu}有一個子分類{a1},{a1}也有一個子分類{a2},如果不用遞歸我們就無法徹底刪除數據。

三、查找
1.查找{電腦}的子分類
復制代碼 代碼如下:
SELECT * FROM `type` WHERE `fid`=2

2.查找{電腦}的所有子分類
復制代碼 代碼如下:
function sel($fid) {
    $sql="SELECT * FROM `type` WHERE `fid`=$fid";
    $rs=mysql_query($sql);

    for ($i = 0; $i < count($rs); $i++) {
        echo $rs[$i]['name'];

        sel($rs[$i]['id']);//遞歸
    }
}
sel(2);

四、實際數據應用
在數據表添加一個字段`tid`,字段值為記錄所屬分類`type`表的id。必須是id不能是name,因為name的值可能會改變。
例如查詢屬于{電腦}分類的商品
復制代碼 代碼如下:
SELECT * FROM `goods` WHERE `tid`=2

注:代碼沒有運行過可能會有錯誤,但是思路是正確的,主要的是理解樹形結構,而不是記住代碼。

php技術基于php無限分類的深入理解,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产精品亚洲高清一区二区 | 亚洲欧美一区二区三区麻豆 | 国产小视频在线播放 | 51国产偷自视频区视频手机播器 | 久久国产亚洲 | 精品国产一区二区三区19 | 精品自拍视频在线观看 | 免费国产一区二区在免费观看 | 日韩三级一区二区三区 | 亚洲图片激情 | 一级做a爰片久久毛片美女 一级做a爰片久久毛片人呢 | 天堂成人在线 | 成人午夜免费视频 | 狠狠干婷婷 | 日本欧美一区二区三区在线 | 五月婷婷六月综合 | www.黄网| 五月婷婷丁香在线观看 | 狠狠插综合 | 久久精品.com| 95视频在线观看在线分类h片 | 亚洲国产天堂久久综合图区 | 亚洲网站视频在线观看 | 亚洲国产精久久久久久久 | 国产精品视频一区二区三区小说 | 一菊综合网成人综合网 | 国产高清www免费视频 | 国产永久免费视频 | 国产福利免费观看 | 精品成人免费一区二区在线播放 | 国产精品制服诱惑 | 色五月婷婷成人网 | 欧美人禽交视频免费观看 | 97人人在线观看 | 欧美麻豆久久久久久中文 | 91电视| 日本三级一区二区 | 国产在线拍揄自揄视精品不卡 | 玖玖爱国产| 成人在线激情网 | 95在线观看精品视频 |