用数据表创建树

小松哥哈哈

小松哥哈哈

2016-02-19 14:18

今天图老师小编给大家展示的是用数据表创建树,精心挑选的内容希望大家多多支持、多多分享,喜欢就赶紧get哦!
 

  数据库结构:
  字段      类型
  ID          整型     索引(无重复)
  name      文本
  father     整型
  
  
  
  //tree初始化
  procedure TForm1.FormActivate(Sender: TObject);
    var i:integer;
  begin
    treeview1.Items.BeginUpdate;
    while not(adotable1.Eof) do
    begin
      if ADOTable1.FieldValues['father']=0 then
        treeview1.Items.addchild(treeview1.DropTarget,ADOTable1.FieldValues['name'])
      else
      begin
        i:=0;
        repeat
          if treeview1.Items.Item[i].Text = ADOTable1.Lookup('ID',ADOTable1.FieldValues['father'],'name') then
          begin
            treeview1.Items.AddChild(treeview1.Items.Item[i],ADOTable1.FieldValues['name']);
            break;
          end;
          i:=i+1;
        until iadotable1.RecordCount;
      end;
      ADOTable1.next;
    end;
    treeview1.Items.EndUpdate;
  end;

  //tree添加
  procedure TForm1.Button1Click(Sender: TObject);
    var i:integer;
  begin
    adotable1.Last;
    i:=adotable1.FieldValues['ID'];
    if checkbox1.Checked=false then
    begin
      adotable1.InsertRecord([edit1.Text,adotable1.Lookup('name',treeview1.Selected.Text,'ID'),i+1]);
      treeview1.Items.AddChild(treeview1.Selected,edit1.Text);
    end
    else
    begin
      adotable1.InsertRecord([edit1.Text,0,i+1]);
      treeview1.Items.AddChild(treeview1.DropTarget,edit1.Text);
    end;
  end;

  //tree删除
  procedure TForm1.Button3Click(Sender: TObject);
  begin
    if treeview1.Selected.HasChildren then
    begin
      showmessage('含有子项,不能删除.');
      abort;
    end;
    begin
      adotable1.Locate('name',treeview1.Selected.Text,[loPartialKey]);
      adotable1.Delete;
      treeview1.Items.Delete(treeview1.Selected);
    end;
  end;

  //tree图标
  procedure TForm1.TreeView1GetImageIndex(Sender: TObject; Node: TTreeNode);
  begin
    if Node.Expanded then
      Node.ImageIndex := 1
    else
      Node.ImageIndex := 0
  end;

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/bianchengyuyan/)

  //tree图标
  procedure TForm1.TreeView1GetSelectedIndex(Sender: TObject;Node: TTreeNode);
  begin
    node.SelectedIndex:=node.ImageIndex;
  end;

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/bianchengyuyan/)

  //list初始化
  procedure TForm1.TreeView1MouseDown(Sender: TObject; Button: TMouseButton;Shift: TShiftState; X, Y: Integer);
    var p:pointer;
  begin
    listview1.Items.Clear;
    if adotable2.Locate('class',adotable1.Lookup('name',treeview1.Selected.Text,'ID'),[loPartialKey])=true then
    begin
      p:=listview1.Items.Add;
      listview1.Items.Item[listview1.Items.IndexOf(p)].Caption:=adotable2.FieldValues['name'];
      listview1.Items.Item[listview1.Items.IndexOf(p)].SubItems.Add(adotable2.FieldValues['url']);
    end;
  end;

  //list添加
  procedure TForm1.Button2Click(Sender: TObject);
    var p:pointer;
  begin
    p:=listview1.Items.Add;
    listview1.Items.Item[listview1.Items.IndexOf(p)].Caption:=edit2.Text;
    listview1.Items.Item[listview1.Items.IndexOf(p)].SubItems.Add(edit3.Text);
    adotable2.InsertRecord([adotable1.Lookup('name',treeview1.Selected.Text,'ID'),edit2.Text,edit3.Text]);
  end;

  //list删除
  procedure TForm1.Button4Click(Sender: TObject);
  begin
    adotable2.Locate('name',listview1.Selected.Caption,[loPartialKey]);
    adotable2.Delete;
    listview1.Selected.Delete;
  end;

展开更多 50%)
分享

猜你喜欢

用数据表创建树

编程语言 网络编程
用数据表创建树

Oracle 9i创建数据表

编程语言 网络编程
Oracle 9i创建数据表

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

MYSQL教程:检查数据表和修复数据表

编程语言 网络编程
MYSQL教程:检查数据表和修复数据表

用AdoDataSet实现数据表的导入导出

Delphi
用AdoDataSet实现数据表的导入导出

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

数据表中数据的管理

编程语言 网络编程
数据表中数据的管理

如何锁定MYSQL数据表

MySQL mysql数据库
如何锁定MYSQL数据表

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

什么是DIV+CSS?

什么是DIV+CSS?

控件移动类的实现之一

控件移动类的实现之一
下拉加载更多内容 ↓