欢迎光临
我们一直在努力

delphi中根据分类数据生成树形结构的最优方法_delphi教程

建站超值云服务器,限时71元/月

 

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


赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » delphi中根据分类数据生成树形结构的最优方法_delphi教程
分享到: 更多 (0)