手机站
网通分站
电信主站
密 码:
用户名:
当前位置 : 主页>程序设计>delphi>列表

Delphi中根据分类数据生成树形结构的最优方法

来源:互联网 作者:西部数码 时间:2008-04-09
西部数码-全国虚拟主机10强!40余项虚拟主机管理功能,全国领先!双线多线虚拟主机南北访问畅通无阻!免费赠送企业邮局,.CN域名,自助建站480元起,免费试用7天,满意再付款! P4主机租用799元/月.月付免压金!

很多系统都有类似于如下的表结构(table1):

ID Name ParentID

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

001 电子类 0

002 金属类 0

003 电容电子 001

004 电阻电子 001

005 有色金属 002

而且大家都习惯于用树(TreeView)来显示,这样就可以很好的显示整个表的分类情况。但如果数据量多时会造成树的生成比较慢,特别是用递归来实现时要访问数据库的次数很多(根据层数),用在三层中效果更加显。在此提供一个好的方法来生成树形结构。

这个算法只访问一次数据库,具体的实现如下:

1、一次性从数据库中取出所有的数据,并按照ParentID字段进行排序,这样就保证每一条数据的父节点都在它的前面。

2、取出第一条数据画到树中,在添加到树中时先找到这条数据的父节点,如果没有 则将此记录直接作为树的第一级节点

3、如果还有数据,则取出来执行第2步,直到没有数据为止。

程序实现:

本程序将用一个stlID的TStringList变量来存放对应树中每一个节点的ID值,用FindParent函数来父节点。

function FindParent(ID:String):TTreeNode;

var

i:Integer;

begin

result:=nil;

for i:=TreeView1.Items.Count-1 downto 0 do

if stlID.Strings[i]=ID then

begin

result:=TreeView1.Items[i];

break;

end;

end;

//生成树

procedure CreateTree;

var

tmpNode:TTreeNode;

begin

Query1.close;

Query1.SQL.Text:=''''select * from table1 order by ParentID'''';

Query1.Open;

Query1.First;

while not Query1.Eof do

begin

tmpNode:=TreeView1.Items.AddChild(FindParent(Query1.FieldByName(''''ParentID'''').AsString),Query1.FieldByName(''''Name'''').AsString);

stlID.Add(Query1.FieldByName(''''ID'''').AsString);//记录ID

Query1.Next;

end;

end;

文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!