您现在的位置: > 首页 > 程序开发 > Delphi教程
>> 最新教程
>> 热门教程
>> 最新游戏资讯
>> 热门游戏资讯
Delphi中根据分类数据生成树形结构的最优方法
作者:本站                来自:安迪教程网                 加入时间:08-11-19                进入论坛讨论

  数据库 

  很多系统都有类似于如下的表结构(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;

联系方式:QQ:6084884 email:agwcn@126.com 粤ICP备05055782号
本网站中发布的文章只代表发表人的个人观点,不代表安迪教程网网站的立场
copyright© 2000-2004 安迪教程网 All rights reserved agwcn.com