delphi中根据分类数据生成树形结构的最优方法
很多系统都有类似于如下的表结构(table1):IDNameParentID-----------------------------------------------...
很多系统都有类似于如下的表结构(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;
------------------------
问题:1.上面的stlID、result是什么,什么意思,作用是什么?
2.上面的代友中,都用到表中什么字段(ID、Name、ParentID)
3.除了上面代码,还有什么可行的、好的代码(速度快)
谢谢了 展开
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;
------------------------
问题:1.上面的stlID、result是什么,什么意思,作用是什么?
2.上面的代友中,都用到表中什么字段(ID、Name、ParentID)
3.除了上面代码,还有什么可行的、好的代码(速度快)
谢谢了 展开
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询