实现树状结构的两种方法

2016-02-19 11:08 123 1 收藏

人生本是一个不断学习的过程,在这个过程中,图老师就是你们的好帮手,下面分享的实现树状结构的两种方法懂设计的网友们快点来了解吧!

【 tulaoshi.com - Web开发 】


实现树状结构的两种方法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("ul");
    while($ra = mysql_fetch_row($rs)) {
        /* 显示记录标题 */
        echo('li'.$ra[0].'/li');
        /* 递归调用 */
        tree($ra[1]);
    }
    echo("/ul");
}
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("ul");
    while($ra = mysql_fetch_row($rs)) {
        /* 显示记录标题 */
        echo('li'.$ra[0].'/li');
        /* 递归调用 */
        tree($ra[1]);
    }
    echo("/ul");
}
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("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");
?

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


插入数据程序

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);?

来源:https://www.tulaoshi.com/n/20160219/1596624.html

延伸阅读
标签: ASP
  在维护公司内部网站时碰到一个实际问题——MIS主管要求将一些技术文件放在网页上,且只能让MIS 的员工浏览。这就涉及到如何对网页保密的问题。 最初我借助Frontpage和Vbscript设计了一种方案,链接MIS技术页(此处预设为actpwdrst.htm)之前,先 链接actpwd.htm输入名称和密码(此处名称和密码都预设 为“mis”),只有正确输入后,...
标签: 电脑入门
Djvu是一种用于保存图书的文件格式,不少书现在都是用的.djvu的影印扫描件,这对于习惯了用PDF的我来说,阅读还是相当麻烦的,毕竟我总不能为了看这个,再单独装个莫名其妙的软件吧,于是开始想办法把djvu转换成PDF。 在这里图老师小编介绍两种方法: 方法一:用Irfanview这个软件,打开djvu文件,直接另存为。OK!效果绝对一流。 唯一需要的...
标签: flash教程
第一种方法,遮罩法。 遇到复杂的曲线时,遮罩就只能用刷子每一帧每一帧地画,每画完一帧,后一帧按F6,接着上一帧开始画!方法比较直观,而且显现的曲线就是和引导线的一样,但是显得有点繁锁! 第二种方法,AS法。 我这里写得AS比较简单!优点是去除了繁锁的画遮罩过程,犹其当引导线出现交叉时,更显方便,可能曲线放大很多时看会显出不平...
标签: ASP
  加贴存储过程: if exists (select * from sysobjects where id = object_id("lybsave"))    drop proc lybsave CREATE PROCEDURE [lybsave] @keyid int=0,@guestname varchar(20),@guestitle varchar(100),@guestcomm text,@guestemail varchar(50)='',@emailflag bit=0,@fromip varchar(15),@recimail varc...
我的主页: http://www.tommstudio.com/ 在应用程序中引入图片淡入及淡出,可以让用户界面更加美观。以前报刊杂志中介绍 的常用方法有两种:一是自己写程序,诸个象素进行混合渐变;二是使用DirectX,建立一 个带Alpha通道的Surface。第一种,效果可以自己控制,但比较麻烦,而且一般不容易生 成硬件优化的代码;第二种速度很快,...

经验教程

912

收藏

58
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部