亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > PHP > 正文

解析thinkphp的左右值無限分類

2020-03-22 20:27:28
字體:
供稿:網(wǎng)友
以前一直使用父子無限分類,這種分類結(jié)構清晰,使用也簡單。但若分類數(shù)量很大的話,在查詢上性能不佳。比如在做導航菜單中,我要根據(jù)某一分類查詢出整個分類樹的話(祖輩)。
性能消耗是非常大的,要么做遞歸,要么做多次查詢。故,對于分類的數(shù)據(jù)量很大的情況,我推薦使用左右值,以減少查詢上的麻煩。
復制代碼 代碼如下:
_id
/**
+----------------------------------------------------------
* html' target='_blank'>構造函數(shù)
* @access public
* @return void
+----------------------------------------------------------
*/
public function __construct($left,$right,$id){
parent::__construct();
$this- _left = $left;
$this- _right = $right;
$this- _id = $id;
}
/**
+----------------------------------------------------------
* 根據(jù)node$this- _id得到該node的所有值
* @access public
* @param $nodeId
* @return array
+----------------------------------------------------------
*/
public function getNodeById($nodeId)
{
if($nodeId 0)
{
return $this- getById($nodeId);
}
else
{
throw_exception('未知$this- _id');
return false;
}
}
/**
+----------------------------------------------------------
* 獲取父節(jié)點,含直屬父類(type=1),所有父類:type=0
* @access public
* @param $nodeId int 節(jié)點$this- _id
* @return $parentNode array()
+----------------------------------------------------------
*/
public function getParentNode($nodeId,$type = 0)
{
if($nodeId == 0) throw_exception('未知$this- _id');;
$currentNode = $this- getNodeById($nodeId);
if($currentNode)
{
$condition = " ".$this- _left.' '.$currentNode[$this- _left].' and '.$this- _right.' '.$currentNode[$this- _right]." ";
if($type ==1) //直屬父類
{
return $this- where($condition)- order($this- _left." DESC")- limit(1)- find();
// $sql = "SELECT * FROM ".TABLE_NAME." WHERE {$condition} ORDER BY ".$this- _left." DESC LIMIT 1";
// return mysql_query($sql) or die(mysql_error());
}
else if($type ==0)
{
return $this- where($condition)- findAll();
// $sql = "SELECT * FROM ".TABLE_NAME." WHERE {$condition} ";
// return mysql_query($sql) or die(mysql_error());
}
}
else
{
return false;
}
}
/**
+----------------------------------------------------------
* 當前節(jié)點下子孫節(jié)點總數(shù).子孫總數(shù)=(當前節(jié)點的右值 - 當前節(jié)點的左值-1)/2
* @access public
* @param $node_id int 節(jié)點$this- _id
* @return $amount int 該節(jié)點下的子孫總數(shù) *
+----------------------------------------------------------
*/
public function getChildCount($nodeId)
{
$currentNode = $this- getNodeById($nodeId);
if(!empty($currentNode))
{
return (int)($currentNode[$this- _right]-$currentNode[$this- _left] -1)/2;
}
}
/**
+----------------------------------------------------------
* 獲取當前節(jié)點下所有子節(jié)點。 當 A子類的右節(jié)點=B子類左節(jié)點-1 則 A、B屬于同一級別
* @access public
* @param $curentId
* @param $type int 0:當前節(jié)點下所有子類,1為當前節(jié)點下一級子類
* @return bool
+----------------------------------------------------------
*/
public function getChild($nodeId,$type=0)
{
$currentNode = $this- getNodeById($nodeId);
if($currentNode[$this- _left]-$currentNode[$this- _right] ==1)
{
return false; //當 該節(jié)點左值 - 右值=1 時,其下沒有子節(jié)點。
}
else
{
$condition = $this- _left.' '.$currentNode[$this- _left].' and '.$this- _right .' '.$currentNode[$this- _right];
$child = $this- where($condition)- findAll();
if($type == 0)//所有子類
{
return $child;
}
else if($type ==1) //獲取當前節(jié)點下一級分類
{
$subArr = array(); //一級子類
foreach ($child as $k= $sub) {
//子類的左節(jié)點=父類左節(jié)點+1,則子類為第一個子類
if($sub[$this- _left]==$currentNode[$this- _left]+1)
{
//$right = $sub[$k][$this- _right]; //當前節(jié)點的右節(jié)點
$firstSub = $sub; //當前節(jié)點下第一個子類
array_push($subArr,$firstSub); //子類入棧
unset($child[$k]);
}
}
$rightVal = $firstSub[$this- _right]; //第一個子節(jié)點為比較標志
$childCount = count($child);//剩余子節(jié)點數(shù)
for($i=0;$i $childCount;$i++) //循環(huán)檢索出 同級子節(jié)點
{
foreach ($child as $key = $sub2) {
if($rightVal == $sub2[$this- _left]-1)
{
$rightVal = $sub2[$this- _right]; //把循環(huán)當前的node的右節(jié)點當做比較值
array_push($subArr,$sub2);
unset($child[$key]);
}
}
}
return $subArr;
}
}
}
/**
+----------------------------------------------------------
* 返回當前節(jié)點的完整路徑
* @access public
* @param $nodeId
* @return array
+----------------------------------------------------------
*/
public function getSinglePath($nodeId)
{
$sql = "select parent.* from __TABLE__ as node,__TABLE__ as parent where node.{$this- _left} between parent.{$this- _left}
AND parent.{$this- _right} AND node.{$this- _id} = {$nodeId} order by parent.{$this- _left}";
// echo $sql;
return $this- query($sql);
}
/**
+----------------------------------------------------------
* 添加子節(jié)點,分3種:0:在當前節(jié)點下最后追加一個子節(jié)點;1:在當前節(jié)點下追加第一個子節(jié)點;

2:在當前節(jié)點下的某個子節(jié)點后追加
復制代碼 代碼如下:
* @access public
* @param $currentId int
* @param $nodeName string 新節(jié)點名稱
* @param $targetId int 追加到當前節(jié)點下子節(jié)點的指定節(jié)點后
* @return bool
+----------------------------------------------------------
*/
public function addNode($nodeId,$newData,$type=0,$targetId=0)
{
if(empty($newData))
{
throw_exception('新分類不能為空');
}
$currentNode = $this- getNodeById($nodeId);
switch ($type) {
case 0:
$leftNode = $currentNode[$this- _right]; //新節(jié)點的左值為父節(jié)點的右值
$rightNode = $leftNode+1;
break;
case 1:
$leftNode = $currentNode[$this- _left]+1; //新節(jié)點的左值為父節(jié)點的左值+1
$rightNode = $leftNode+1;
break;
case 2:
$otherNode = $this- getNodeById($targetId);
$leftNode = $otherNode[$this- _right]+1;
$rightNode = $leftNode+1;
default:
break;
}
// $sql = "UPDATE ".TABLE_NAME." SET ".$this- _right."=".$this- _right."+2 WHERE ".$this- _right." = ".$leftNode;
// $sql2 = "UPDATE ".TABLE_NAME." SET ".$this- _left."=".$this- _left."+2 WHERE ".$this- _left." ".$leftNode;
$this- setInc($this- _right,$this- _right." =".$leftNode,2); //把所有右值大于新節(jié)點左值的節(jié)點的右值+2,注意效率
$this- setInc($this- _left,$this- _left." ".$leftNode,2); //把所有大于新節(jié)點的左值+2
$newData[$this- _left] = (int)$leftNode;
$newData[$this- _right] =(int) $rightNode;
return $this- add($newData);
}
/**
+----------------------------------------------------------
* 刪除節(jié)點
* @access public
* @param type 操作類型,默認為0刪除當前節(jié)點下的所有子節(jié)點,1為刪除包括自身的節(jié)點
* @param $nodeId int 要刪除的$this- _id
* @return bool
+----------------------------------------------------------
*/
public function rmNode($nodeId,$type =1)
{
$currentNode = $this- getNodeById($nodeId);
if($type == 1) //刪除包含自身的節(jié)點
{
$sql = "DELETE FROM __TABLE__ WHERE ".$this- _left." = {$currentNode[$this- _left]} AND ".$this- _right." = {$currentNode[$this- _right]}";
$childCount = ($this- getChildCount($nodeId)+1)*2; //要更新的值
$sql2 = "UPDATE __TABLE__ SET ".$this- _right."=".$this- _right."-".$childCount." WHERE ".$this- _right." ".$currentNode[$this- _right];
$sql3 = "UPDATE __TABLE__ SET ".$this- _left."=".$this- _left."-".$childCount." WHERE ".$this- _left." ".$currentNode[$this- _left];
}
else //刪除當前節(jié)點下的所有節(jié)點
{
$sql ="DELETE FROM __TABLE__ WHERE ".$this- _left." {$currentNode[$this- _left]} AND ".$this- _right." {$currentNode[$this- _right]}";
$childCount = $this- getChildCount($nodeId)*2; //要更新的值
$sql2 = "UPDATE __TABLE__ SET ".$this- _right."=".$this- _right ."-".$childCount." WHERE ".$this- _right." =".$currentNode[$this- _right];
$sql3 = "UPDATE __TABLE__ SET ".$this- _left."=".$this- _left."-".$childCount." WHERE ".$this- _left." ".$currentNode[$this- _left];
}
$this- execute($sql);
$this- execute($sql2);
$this- execute($sql3);
return true;
}
/**
+----------------------------------------------------------
* 修改節(jié)點,名稱等
* @access public
* @param $newData array()必須含有 要修改的$this- _id,k-v必須對齊,如arr['node_name'] = '商品'
* @return bool
+----------------------------------------------------------
*/
public function modiNode($newData)
{
if(!empty($newData))
{
$id = $newData[$this- _id];
unset($newData[$this- _id]);
return $this- save($newData,$this- _id.'='.$id);
}
}
}
?

PHP教程

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
四虎亚洲精品| 国产精品香蕉国产| 欧美在线播放一区| 久久久久久久999精品视频| 一区二区久久精品66国产精品| yy4480电影网| 这里只有精品视频| 亚洲男人的天堂成人| 日本黑人久久| a在线播放不卡| 欧美日韩免费观看视频| 国产三级做爰在线观看| 特级xxxxx欧美| 日韩av新片网| 日韩精品专区在线影院重磅| 91在线视频网址| 免费91视频| 国产在线98福利播放视频| 亚洲影院在线看| 波多结衣在线观看| 亚洲伦理影院| 丁香六月综合| 国产欧美高清在线| 国产麻豆精品95视频| 欧美一级在线观看| 亚洲wwwwww| 精品视频久久久| 亚洲精品一区二区网址| 亚洲欧美日韩电影| 校园春色另类视频| 欧美日本另类xxx乱大交| 欧美激情精品久久久久久久变态| 久久久久久久久久久一区| 日韩在线伦理| 日本欧美大码aⅴ在线播放| 亚洲一区二区三区欧美| 国产伦精品一区二区三区视频痴汉| 欧美电影网址| 亚洲美腿欧美偷拍| 亚洲曰韩产成在线| www怡红院| 日韩国产精品久久久| 国产精品美女久久久| 伊人福利在线| 亚洲一区二区三区成人在线视频精品| 韩国一区二区电影| 亚洲国产精品成人av| 国产精品久久久毛片| 亚洲精品美女在线| 在线观看亚洲黄色| 亚洲一区二区三区不卡国产欧美| 91丨九色丨海角社区| 日韩在线观看一区| 亚洲美女15p| 97精品国产97久久久久久春色| 日韩小视频在线| 亚洲欧美偷拍自拍| 日韩电影免费网站| 丝袜+亚洲+另类+欧美+变态| 伊人亚洲综合网| 99麻豆久久久国产精品免费| 99久久精品无码一区二区毛片| 久久久久日韩精品久久久男男| 成人av电影在线| av一区二区三区在线| 亚洲人成影院在线| 欧美xxxx黑人| 国产精品毛片a∨一区二区三区|国| 99精品在免费线中文字幕网站一区| 九九在线高清精品视频| 痴汉一区二区三区| 日韩一区二区三区在线观看| 91亚洲精品丁香在线观看| 欧美性色视频在线| 中文字幕在线永久| 欧美福利电影网| 麻豆mv在线观看| 成人在线手机视频| 中文字幕精品影院| 警花av一区二区三区| 国产精品99久久久久久久vr| 中文在线网在线中文| 伊人中文字幕在线观看| 欧洲成人一区二区| 欧美一二三四五区| av资源免费观看| 中文字幕一区二区三区有限公司| 国内成人自拍| 国产精品不卡在线| 91啪九色porn原创视频在线观看| 美女免费免费看网站| 毛片在线视频| 一个色在线综合| 超碰在线播放97| 亚洲精品日韩一| 国产 高清 精品 在线 a| 精品久久久免费| 亚洲免费一区二区| 欧美日本二区| 日韩欧美在线视频| 亚洲一区在线观看免费观看电影高清| 午夜激情久久久| 国产精品成熟老女人| 国产九九九视频| 在线电影国产精品| 亚洲网址在线观看| 欧美日韩国产在线观看| 91成人免费网站| 在线视频91p| 狠狠入ady亚洲精品经典电影| 亚洲精品怡红院| 国产精品又粗又长| 一区二区国产欧美| 年下总裁被打光屁股sp| 成人久久综合| 日韩视频在线一区二区| 久久99久久99精品免观看粉嫩| 在线观看免费成人av| 蜜桃视频在线观看成人| 青青草偷拍视频| 手机av在线播放| 日韩精品一区二区av| 欧产日产国产v| 国产露脸91国语对白| 成年人看片网站| 国产欧美日韩在线播放| 国产精品69av| 亚洲国产无码精品| 网站在线观看你懂的| 日本视频一区二区不卡| 日韩精品一区二区三区四区视频| 蜜乳av另类精品一区二区| 欧美极品一区二区| 日韩大片免费在线观看| 久久久久久久穴| 日本女人性视频| 日韩欧美一区二区三区在线观看| 欧美一区二区三区影视| eeuss影院www在线观看免费| av网站在线免费| 91精品国产91久久久久久一区二区| 樱花视频在线免费观看| 欧美日免费三级在线| 国产欧美日产一区| 国产福利91精品一区二区| 日本一区二区三区免费乱视频| 成年人免费在线播放| 日本一区午夜艳熟免费| 免费人成在线观看网站| 色av一区二区三区| 日日噜噜夜夜狠狠视频| 亚洲女人天堂成人av在线| 九九精品在线视频| 国产美女久久精品香蕉69| 久久免费视频99| 成人在线视频免费播放| 国产无套精品一区二区三区| 黄色一级视频在线播放| 任你操这里只有精品| 亚洲va久久久噜噜噜久久狠狠| 男人女人靠逼视频| 夜夜爽av福利精品导航| 久久精品视频9| 色婷婷av一区二区三区丝袜美腿| 日本不卡高字幕在线2019| 日本三级电影免费观看| 久久久国产精品麻豆| 懂色av中文一区二区三区天美| 91看片在线播放| 欧美黄色性生活| 免费的一级黄色片| 国产麻豆视频一区| 美女网站久久| 免费在线稳定资源站| 亚洲天堂网视频| 爽爽视频在线观看| 成人黄色电影在线| 日日橹狠狠爱欧美超碰| 天天操天天爽天天射| gogo亚洲国模私拍人体| 欧美自拍一区| www四虎com| 欧美区二区三区| 黑人巨大精品欧美一区二区| 欧美日韩一区国产| 国产一二三区在线视频| 久久精品论坛| www.色视频| 亚洲国产精品久久久久秋霞蜜臀| 五月综合激情在线| 91精品国产综合久久精品性色| 一区二区三区午夜视频| 久久精品久久精品亚洲人| 美美哒免费高清在线观看视频一区二区| 毛片在线播放网站| 成人动漫一区二区| 国产真人做爰毛片视频直播| 精品人妻一区二区三区麻豆91| 999国产精品999久久久久久| 日本a级片电影一区二区| 春日野结衣av| 亚洲电影免费观看高清| 深夜精品寂寞黄网站在线观看| 日韩av一卡二卡| 欧美日韩午夜| 免费观看一级特黄欧美大片| 欧美成人在线直播| 亚洲av无码一区二区三区dv| 国内精品伊人久久久久av一坑| 国产成人a亚洲精v品无码| 欧美粗暴性video| aaa大片在线观看| 亚洲性图第一页| 老太脱裤子让老头玩xxxxx| 麻豆高清免费国产一区| 日韩欧美激情一区二区| 日韩精品免费一区二区| 91黑丝在线观看| 日本中文一区二区三区| www亚洲人| 日韩av在线网站| 奇米影视四色在线| 秋霞成人午夜鲁丝一区二区三区| 国产婷婷成人久久av免费高清| 日本少妇裸体做爰| 亚洲国产日韩在线一区| 天堂午夜影视日韩欧美一区二区| 欧美成人激情图片网| 亚洲第一二三四五区| 思思久久精品视频| 国产精品自拍偷拍视频| 欧美视频1区| 久久黄色美女电影| 色午夜这里只有精品| 日本三级网站在线观看| 超碰91人人草人人干| 最近中文在线观看| 致1999电视剧免费观看策驰影院| 亚洲mv在线观看| 蜜桃视频成人在线观看| 久久精品国产v日韩v亚洲| 久久久一本精品99久久精品66| 精品成人私密视频| 国产乱妇无码大片在线观看| 精品国产乱码久久久久久蜜臀网站| 91精品视频一区二区| 欧美成人se01短视频在线看| 波多野结衣视频网站| 久久超级碰视频| 亚洲婷婷国产精品电影人久久| 无码aⅴ精品一区二区三区| 久久精品麻豆| 91精产国品一二三| 欧美亚洲伦理www| 一级二级在线观看| 国产精品亚洲欧美导航| 免费a v网站| 亚洲视频一区二区免费在线观看| 欧美丝袜一区二区三区| 久久综合色8888| 国产成人免费在线观看不卡| 人妻无码一区二区三区四区| 国产在线2020| 亚洲午夜久久久久中文字幕久| 狼狼综合久久久久综合网| 国产白浆在线免费观看| 一区二区三区www污污污网站| 国产91社区| 全国男人的天堂天堂网| 成人一级片在线观看| 精品91一区二区三区| 久草国产在线观看| 精品自拍偷拍视频| 日本一二三区不卡| 久久人人97超碰com| 中文字幕一区二区三区5566| 国产精品国产三级国产试看| 国产91精品久久久久| 亚洲国产视频a| 99这里都是精品| 日韩欧美猛交xxxxx无码| 免费观看又色又爽又黄的网站| 成人综合视频在线| 精品国产一二三四区| 精品二区三区线观看| 日韩大片在线免费观看| 国产精品入口福利| 黄色一级二级三级| 亚洲高清免费在线| 欧美三级电影一区二区三区| av网站大全免费| 中文字幕成人av| crdy在线观看欧美| 操人视频在线观看欧美| 黄网在线免费| 亚洲天堂一区二区在线观看| 久久久久久久久一区二区| xxx免费视频观看| 经典三级在线一区| 国产亚洲综合性久久久影院| 久久久亚洲欧洲日产国码αv| 欧美成a人片在线观看久| 国产精品jvid在线观看| 日韩电影网在线| 欧美激情一区二区久久久| 国产福利免费在线观看| 欧美日韩不卡合集视频| 4438国产精品一区二区| 韩国三级午夜理伦三级三| 精品国产一二三| 久久久久久欧美精品色一二三四| 俄罗斯一级**毛片在线播放| 中国av在线播放| 91久久在线视频| 日韩中文字幕影院| 开心九九激情九九欧美日韩精美视频电影| 亚洲男人天堂2024| 久久人妻无码aⅴ毛片a片app| 在线免费视频你懂得| 色88888久久久久久影院按摩| 欧美日韩国产精品一卡| 大j8黑人w巨大888a片| 欧美一二三区视频| 国产美女久久久久久| 日韩高清成人| 日韩网站免费观看高清| 亚洲人xxxx| 欧美freesex交免费视频|