zoukankan      html  css  js  c++  java
  • Delphi中根据分类数据生成树形结构的最优方法

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

  • 相关阅读:
    Go语言趣学指南lesson3
    简单的>this
    多媒体查询
    解析对象原型链
    笑对人生,坐看云起云落
    HTML5
    javascript函数及作用域的小结
    不得不知call()和apply()
    浅谈弹性盒子布局
    编译原理实验(算符优先文法)
  • 原文地址:https://www.cnblogs.com/karkash/p/3114275.html
Copyright © 2011-2022 走看看