天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

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

無限分類是實際開發(fā)中經(jīng)常用到的一種數(shù)據(jù)結(jié)構(gòu),一般我們稱之為樹形結(jié)構(gòu)。
題設(shè):類似淘寶的商品分類,可以在任意分類設(shè)置其子類。
 
一、創(chuàng)建`type`數(shù)據(jù)表
`id` 自增長
`fid` int(11) 默認(rèn)(0) ,父節(jié)點id
`name` varchar(50),分類名稱
復(fù)制代碼 代碼如下:
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`)
)

二、添加
我們先添加幾個頂級分類
復(fù)制代碼 代碼如下:
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是代表頂級分類

接著我們?yōu)閧電腦}添加幾個個子分類
復(fù)制代碼 代碼如下:
INSERT INTO `type` (`id`, `fid`, `name`) VALUES (NULL, '2', '臺式'), (NULL, '2', '筆記本');

這里fid=2,2這個id是分類{電腦}的id,如果是添加{鞋子}的子分類則fid=3
同理我們?yōu)閧筆記本}添加子分類則fid=6
復(fù)制代碼 代碼如下:
INSERT INTO `type` (`id`, `fid`, `name`) VALUES (NULL, '6', 'ausu'), (NULL, '6', 'hp');

三、刪除
如果我們想刪除{筆記本}這個分類,很簡單
復(fù)制代碼 代碼如下:
DELETE FROM `type` WHERE `id`=6

{筆記本}的子分類我們也要記得做相應(yīng)的處理
復(fù)制代碼 代碼如下:
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);//執(zhí)行操作

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

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

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

2.查找{電腦}的所有子分類
復(fù)制代碼 代碼如下:
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);

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

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

php技術(shù)基于php無限分類的深入理解,轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 久久免费看少妇级毛片蜜臀 | 国产色婷婷亚洲99精品 | 玩弄朋友娇妻呻吟交换电影 | 黄色三级三级三级免费看 | 秋霞电影网午夜一级鲁丝片 | 韩国污动漫无遮掩无删减电脑版 | 無码一区中文字幕少妇熟女网站 | 99re5.久久热在线视频 | 歪歪爽蜜臀AV久久精品人人槡 | 久久高清内射无套 | 2021久久最新国产精品 | 久久亚洲精品2017 | 国产h视频在线观看网站免费 | 秋霞午夜理论理论福利无码 | 99热国产这里只有精品免费 | 国产高清国内精品福利色噜噜 | 中文字幕国产在线观看 | 偷拍精品视频一区二区三区 | 美女挑战50厘米长的黑人 | 国内精品视频在线播放一区 | 大学生宿舍飞机china free | 王小军怎么了最新消息 | 欧美激情精品久久久久 | 亚洲va在线va天堂XX xX | 老太婆性BBWBBW | 亚洲人视频在线观看 | 2020国产成人免费视频 | 国产爱豆果冻传媒在线观看 | 亚洲视频无码中字在线 | 中文有码中文字幕免费视频 | 在线国内自拍精品视频 | 国产精品一区二区在线观看 | 久cao在线香蕉 | 无人区日本电影在线观看 | 桃隐社区最新最快地址 | 精品无码久久久久久久久 | 好大太快了快插穿子宫了 | 国产福利视频一区二区 | 免费看国产曰批40分钟 | 法国剧丝袜情版h级在线电影 | 欧美久久无码AV麻豆 |