实现树状结构图_实现树状结构的两种方法

更新时间:2017-07-27 来源:软件评测 点击:

【www.hzclsc.cn--软件评测】

1。递归法
递归是指在函数中显式的调用它自身。
利用递归法实现树状结构的特点是写入数据速度较快,显示速度较慢(在树的分支/层次较多的情况下尤其明显)。适用与写入数据量大,树的结构复杂的情况下。
数据结构(以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代码:--------------------------------------------------------------------------------

 

/* 数据库连接 */
mysql_connect();
mysql_select_db("tree");

/* 树状显示的递归函数 */
function tree($parentid = 0) {
    /*执行sql查询,获取记录的标题和id*/
    $sql = "select topic,id from tree1 where parentid = $parentid order by id asc";
    $rs = mysql_query($sql);
    /* 缩进*/
    echo("

");
    while($ra = mysql_fetch_row($rs)) {
        /* 显示记录标题 */
        echo(" ".$ra[0]."");
        /* 递归调用 */
        tree($ra[1]);
    }
    echo("

");
}
tree();
?>

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


逆序树:

PHP代码:--------------------------------------------------------------------------------

 

/* 数据库连接 */
mysql_connect();
mysql_select_db("tree");

/* 树状显示的递归函数 */
function tree($parentid = 0) {
    /*执行sql查询,获取记录的标题和id*/
    $sql = "select topic,id from tree1 where parentid = $parentid order by id desc";
    $rs = mysql_query($sql);
    /* 缩进*/
    echo("

");
    while($ra = mysql_fetch_row($rs)) {
        /* 显示记录标题 */
        echo(" ".$ra[0]."");
        /* 递归调用 */
        tree($ra[1]);
    }
    echo("

");
}
tree();
?>

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


插入数据程序

PHP代码:--------------------------------------------------------------------------------

 

/* 数据库连接 */
mysql_connect();
mysql_select_db("tree");
$sql = "insert into tree (topic,parentid) values("树3-1",3);";
mysql_query($sql);
?>

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


2。排序字段法
此方法是通过在数据结构中增加一个标志记录在整个树中的顺序位置的字段来实现的。特点是显示速度和效率高。但在单个树的结构复杂的情况下,数据写入效率有所不足。而且顺序排列时候,插入,删除记录的算法过于复杂,故通常用逆序排列。

数据结构(以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代码:--------------------------------------------------------------------------------

 

/* 数据库连接 */
mysql_connect();
mysql_select_db("tree");

/* 选出所有根记录id */
$sql = "select id from tree2 where parentid = 0 order by id desc";
$rs = mysql_query($sql);
echo("

");
$lay = 0;
while($ra = mysql_fetch_row($rs)) {
    echo(" ");
    /* 选出此树所有记录,并按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(" ",$ra1[1]-$lay));
        }elseif($ra1[1]<$lay) {
            echo(str_repeat(" ",$lay-$ra1[1]));
        }
        /* 记录显示 */
        //echo("$ra1[1]>$lay");
        echo(" $ra1[0]");
        $lay = $ra1[1];
    }
    echo(" ");
}
echo("

");
?>

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


插入数据程序

PHP代码:--------------------------------------------------------------------------------

 

/* 数据库连接 */
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);?>

本文来源:http://www.hzclsc.cn/ruanjianzixun/745.html

为您推荐

[rainway什么意思]Rainway软件下载地址 rainway串流switch软件在哪下载

您的位置:首页 → 单机游戏 → 游戏资讯 → Rainway软件下载地址 rainway串流switch软件在哪下载 Rainway软件下载地址 rainway串流switch软件在哪下载时间:20游戏资讯

2020-12-16 11:04:57  

苹果电脑安全性偏好设置_苹果电脑安全漏洞是什么 苹果电脑安全漏洞无需密码解锁解决办法

就在近日,有用户发现苹果电脑出现了一个重大的安全漏洞,不需要输入密码即可进入系统,但是很多用户都还不知道苹果电脑安全漏洞是什么,好奇的用户马上点击查看苹果电脑安全漏洞无需密码解锁解决办法来防范于未然教你一招

2020-12-10 23:05:05   电脑安全软件   电脑安全证书过期怎么办   顺丰寄电脑安全吗  

【nero】Nelo游戏配置要求高吗 Nelo推荐配置一览

Nelo游戏配置要求高吗?Nelo是一款由虚幻4打造的超快节奏的动作游戏,玩家可以使用四种武器形成各式各样的攻击方式,本文为大家带来Nelo售价和配置要求介绍,下面就一起来看看Nelo推荐配置一览吧。游戏资讯

2020-12-10 11:04:41   nero8中文破解版   nero刻录软件   nero10序列号  

抢红包神器抢最大的_抢红包怎么抢最大的 抢红包助手下载哪个好

时近年末,相信大家的“节目单”上除了与好友聚会叙旧、与客户更加频繁地应酬之外,还有一项必不可少的活动,那就是抢红包。记得木心有首现代诗中是这样写的,“从前的日色变得慢,车马、信件都很慢 ”的软件评测

2020-12-09 17:04:22   抢红包怎么能抢最大的   抢红包最大金额软件  

[wegame修复游戏在哪里]腾讯wegame怎么修复游戏 wegame平台修复游戏教程

您的位置:首页 → 资讯 → 游戏软件 → 腾讯wegame怎么修复游戏 wegame平台修复游戏教程 腾讯wegame怎么修复游戏 wegame平台修复游戏教程时间:2017 10 20 16:00游戏软件

2020-12-04 07:04:50   wegame游戏修复在哪里   wegame如何修复游戏