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

Delphi中根据分类数据生成树形结构的最优方法 (转)[@more@]

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


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10752019/viewspace-958564/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10752019/viewspace-958564/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值