實現(xiàn)樹狀結構的兩種方法1。遞歸法
遞歸是指在函數(shù)中顯式的調用它自身。
利用遞歸法實現(xiàn)樹狀結構的特點是寫入數(shù)據(jù)速度較快,顯示速度較慢(在樹的分支/層次較多的情況下尤其明顯)。適用與 " /> 亚洲午夜久久久精品电影院,忘忧草下载,使劲别停好大好深好爽动态图

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

實現(xiàn)樹狀結構的兩種方法


實現(xiàn)樹狀結構的兩種方法1。遞歸法
遞歸是指在函數(shù)中顯式的調用它自身。
利用遞歸法實現(xiàn)樹狀結構的特點是寫入數(shù)據(jù)速度較快,顯示速度較慢(在樹的分支/層次較多的情況下尤其明顯)。適用與寫入數(shù)據(jù)量大,樹的結構復雜的情況下。
數(shù)據(jù)結構(以mysql為例)

代碼:--------------------------------------------------------------------------------
CREATE TABLE `tree1` (
  `id` tinyint(3) unsigned NOT NULL auto_increment,
  `parentid` tinyint(3) unsigned NOT NULL default '0',
  `topic` varchar(50) default NULL,
  PRIMARY KEY  (`id`),
  KEY `parentid` (`parentid`)
) TYPE=MyISAM;

INSERT INTO `tree1` (`id`, `parentid`, `topic`) VALUES
  (1,0,'樹1'),
  (2,0,'樹2'),
  (3,0,'樹3'),
  (4,2,'樹2-1'),
  (5,4,'樹2-1-1'),
  (6,2,'樹2-2'),
  (7,1,'樹1-1'),
  (8,1,'樹1-2'),
  (9,1,'樹1-3'),
  (10,8,'樹1-2-1'),
  (11,7,'樹1-1-1'),
  (12,11,'樹1-1-1-1');
--------------------------------------------------------------------------------


字段說明
id,記錄的id號
parentid,記錄的父記錄id(為0則為根記錄)
topic,記錄的顯示標題

顯示程序

順序樹:

php代碼:--------------------------------------------------------------------------------

<?
/* 數(shù)據(jù)庫連接 */
mysql_connect();
mysql_select_db('tree');

/* 樹狀顯示的遞歸函數(shù) */
function tree($parentid = 0) {
    /*執(zhí)行sql查詢,獲取記錄的標題和id*/
    $sql = "select topic,id from tree1 where parentid = $parentid order by id asc";
    $rs = mysql_query($sql);
    /* 縮進*/
    echo("<ul>");
    while($ra = mysql_fetch_row($rs)) {
        /* 顯示記錄標題 */
        echo('<li>'.$ra[0].'</li>');
        /* 遞歸調用 */
        tree($ra[1]);
    }
    echo("</ul>");
}
tree();
?>

--------------------------------------------------------------------------------


逆序樹:

php代碼:--------------------------------------------------------------------------------

<?
/* 數(shù)據(jù)庫連接 */
mysql_connect();
mysql_select_db('tree');

/* 樹狀顯示的遞歸函數(shù) */
function tree($parentid = 0) {
    /*執(zhí)行sql查詢,獲取記錄的標題和id*/
    $sql = "select topic,id from tree1 where parentid = $parentid order by id desc";
    $rs = mysql_query($sql);
    /* 縮進*/
    echo("<ul>");
    while($ra = mysql_fetch_row($rs)) {
        /* 顯示記錄標題 */
        echo('<li>'.$ra[0].'</li>');
        /* 遞歸調用 */
        tree($ra[1]);
    }
    echo("</ul>");
}
tree();
?>

--------------------------------------------------------------------------------


插入數(shù)據(jù)程序

php代碼:--------------------------------------------------------------------------------

<?
/* 數(shù)據(jù)庫連接 */
mysql_connect();
mysql_select_db('tree');
$sql = "insert into tree (topic,parentid) values('樹3-1',3);";
mysql_query($sql);
?>

--------------------------------------------------------------------------------


2。排序字段法
此方法是通過在數(shù)據(jù)結構中增加一個標志記錄在整個樹中的順序位置的字段來實現(xiàn)的。特點是顯示速度和效率高。但在單個樹的結構復雜的情況下,數(shù)據(jù)寫入效率有所不足。而且順序排列時候,插入,刪除記錄的算法過于復雜,故通常用逆序排列。

數(shù)據(jù)結構(以mysql為例)

代碼:--------------------------------------------------------------------------------
CREATE TABLE `tree2` (
  `id` tinyint(3) unsigned NOT NULL auto_increment,
  `parentid` tinyint(3) unsigned NOT NULL default '0',
  `rootid` tinyint(3) unsigned NOT NULL default '0',
  `layer` tinyint(3) unsigned NOT NULL default '0',
  `orders` tinyint(3) unsigned NOT NULL default '0',
  `topic` varchar(50) default NULL,
  PRIMARY KEY  (`id`),
  KEY `parentid` (`parentid`),
  KEY `rootid` (`rootid`)
) TYPE=MyISAM

INSERT INTO `tree2` (`id`, `parentid`, `rootid`, `layer`, `orders`, `topic`) VALUES
  (1,0,1,0,0,'樹1'),
  (2,0,2,0,0,'樹2'),
  (3,0,3,0,0,'樹3'),
  (4,2,2,1,2,'樹2-1'),
  (5,4,2,2,3,'樹2-1-1'),
  (6,2,2,1,1,'樹2-2'),
  (7,1,1,1,4,'樹1-1'),
  (8,1,1,1,2,'樹1-2'),
  (9,1,1,1,1,'樹1-3'),
  (10,8,1,2,3,'樹1-2-1'),
  (11,7,1,2,5,'樹1-1-1'),
  (12,11,1,3,6,'樹1-1-1-1');
--------------------------------------------------------------------------------


顯示程序

php代碼:--------------------------------------------------------------------------------

<?
/* 數(shù)據(jù)庫連接 */
mysql_connect();
mysql_select_db('tree');

/* 選出所有根記錄id */
$sql = "select id from tree2 where parentid = 0 order by id desc";
$rs = mysql_query($sql);
echo("<ul>");
$lay = 0;
while($ra = mysql_fetch_row($rs)) {
    echo("<ul>");
    /* 選出此樹所有記錄,并按orders字段排序 */
    $sql = "select topic,layer from tree2 where rootid = $ra[0] order by orders";
    $rs1 = mysql_query($sql);
    while($ra1 = mysql_fetch_row($rs1)) {
        /* 縮進顯示 */
        if($ra1[1]>$lay) {
            echo(str_repeat("<ul>",$ra1[1]-$lay));
        }elseif($ra1[1]<$lay) {
            echo(str_repeat("</ul>",$lay-$ra1[1]));
        }
        /* 記錄顯示 */
        //echo("$ra1[1]>$lay");
        echo("<li>$ra1[0]</li>");
        $lay = $ra1[1];
    }
    echo("</ul>");
}
echo("</ul>");
?>

--------------------------------------------------------------------------------


插入數(shù)據(jù)程序

php代碼:--------------------------------------------------------------------------------

<?
/* 數(shù)據(jù)庫連接 */
mysql_connect();
mysql_select_db('tree');

/* 插入根記錄 */
$sql = "insert into tree2 (topic) values ('樹5')";
mysql_query($sql);
$sql = "update tree2 set rootid = id where id = ".mysql_insert_id();
mysql_query($sql);

/* 插入子記錄 */
$parentid = 5;//父記錄id
/* 取出 根記錄id,父記錄縮進層次,父記錄順序位置 */
$sql = "select rootid,layer,orders from tree2 where id = $parentid";
list($rootid,$layer,$orders) = mysql_fetch_row(mysql_query($sql));
/* 更新插入位置后記錄的orders值 */
$sql = "update tree2 set orders = orders + 1 where orders > $orders";
mysql_query($sql);
/* 插入記錄 */
$sql = "insert into tree2 (rootid,parentid,orders,layer,topic) values ($rootid,$parentid,".($orders+1).",".($layer+1).",'樹2-1-1-2')";
mysql_query($sql);?>

php技術實現(xiàn)樹狀結構的兩種方法,轉載需保留來源!

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

主站蜘蛛池模板: 八妻子秋霞理在线播放 | 国产又爽又黄又不遮挡视频 | 小小水蜜桃视频高清在线观看免费 | 一一本之道高清视频在线观看中文字幕 | 4480YY旧里番在线播放 | 精品国产一区二区三区久久影院 | 国产一区私人高清影院 | 久久re6热在线视频精品66 | 午夜亚洲WWW湿好大 午夜性爽视频男人的天堂在线 | 国产精品自产拍在线观看网站 | 久久三级网站 | 一区二区三区国产 | proburn中文破解版下载 | 天天操天天干天天爽 | 99香蕉视频 | 日本妞欧洲 | 亚洲免费一区二区 | 亚洲人成网站在线观看90影院 | 99亚洲精品 | 久久久久久久伊人电影 | 国产性夜夜性夜夜爽91 | 国产无遮挡又黄又爽在线视频 | 91亚洲精品福利在线播放 | 欧美亚洲精品午夜福利AV | 香蕉尹人综合精品 | 语文老师扒开胸罩喂我奶 | 国产99久久久国产精品免费看 | 精品无码国产自产在线观看水浒传 | 女王黄金vk| 亚洲AV无码乱码国产精品品麻豆 | 欲奴第一季在线观看全集 | 青青久在线视频免费观看 | 国产精品私人玩物在线观看 | 视频三区 国产盗摄 | 打卡中国各地奋斗第一线 | 办公室沙发口爆12P 办公室日本肉丝OL在线 | 欧美成人中文字幕在线看 | 一线高清视频在线播放 | 性色爽爱性色爽爱网站 | yellow免费观看在线 | 掀开奶罩边躁狠狠躁软学生 |