zoukankan      html  css  js  c++  java
  • delphi学习treeview中从表列名和数据添加为目录并双击自动选中




    1 unit Unit2; 2 3 interface 4 5 uses 6 Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, 7 Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Data.DB, Data.Win.ADODB, Vcl.Grids, 8 Vcl.DBGrids, Vcl.ComCtrls, Vcl.StdCtrls; 9 10 type 11 TForm2 = class(TForm) 12 TreeView1: TTreeView; 13 DBGrid1: TDBGrid; 14 ADOConnection1: TADOConnection; 15 ADOQuery1: TADOQuery; 16 DataSource1: TDataSource; 17 procedure FormShow(Sender: TObject); 18 procedure TreeView1DblClick(Sender: TObject); 19 private 20 { Private declarations } 21 public 22 { Public declarations } 23 end; 24 25 var 26 Form2: TForm2; 27 28 implementation 29 30 {$R *.dfm} 31 32 procedure TForm2.FormShow(Sender: TObject); 33 var 34 I: Integer; 35 node: TTreeNode; 36 MyFuAdq,MyZiAdq: TADOQuery; 37 begin 38 MyFuAdq := TADOQuery.Create(nil); 39 MyZiAdq := TADOQuery.Create(nil); 40 try 41 MyFuAdq.Connection := ADOConnection1; 42 MyZiAdq.Connection := ADOConnection1; 43 with MyFuAdq do 44 begin 45 SQL.Text := 'SELECT TOP 1 * FROM top_order'; 46 Open; 47 end; 48 49 for I := 0 to MyFuAdq.FieldDefs.Count - 1 do 50 begin 51 node := TreeView1.Items.Add(nil, MyFuAdq.FieldDefs[I].Name); {字段名} 52 53 //再次查询每列不同的数据 54 with MyZiAdq do 55 begin 56 Close; 57 SQL.Text := 'SELECT DISTINCT '+MyFuAdq.FieldDefs[I].Name+ ' FROM top_order'; 58 Open; 59 end; 60 while not MyZiAdq.Eof do 61 begin 62 TreeView1.Items.AddChild(node, MyZiAdq.FieldByName(MyFuAdq.FieldDefs[I].Name).AsString); 63 MyZiAdq.Next; 64 end; 65 end; 66 67 68 finally 69 MyFuAdq.Free; 70 MyZiAdq.Free; 71 end; 72 73 end; 74 75 procedure TForm2.TreeView1DblClick(Sender: TObject); 76 var 77 MyAdq: TADOQuery; 78 selectName,selectValue: string; 79 begin 80 MyAdq := TADOQuery.Create(nil); 81 try 82 MyAdq.Connection := ADOConnection1; 83 84 //获取选中的内容 85 selectName := TreeView1.Selected.Parent.Text; 86 selectValue := TreeView1.Selected.Text; 87 88 //选中 89 with MyAdq do 90 begin 91 SQL.Text := 'UPDATE top_trade SET top_xuanzhong = 1 WHERE top_xuhao IN (SELECT DISTINCT top_xuhao FROM top_order WHERE '+selectName+' = '+selectValue.QuotedString+')'; 92 ExecSQL; 93 end; 94 95 96 //查询 97 with ADOQuery1 do 98 begin 99 Close; 100 SQL.Text := 'SELECT top_order.top_title,top_trade.top_xuhao,top_trade.top_xuanzhong FROM top_order FULL JOIN top_trade ON top_order.top_xuhao = top_trade.top_xuhao WHERE top_order.'+selectName+' = '+selectValue.QuotedString; 101 Open; 102 end; 103 finally 104 MyAdq.Free; 105 end; 106 end; 107 108 end.
    复制代码

  • 相关阅读:
    如何评价ionic和react native?
    ionic 之 基本布局
    TensorFlow中文社区---下载与安装
    深入代码详谈irqbalance【转】
    用Gen4消除电容触摸屏设计屏障【转】
    如何解决触摸屏的电磁干扰问题【转】
    Linux firmware 加载【转】
    Linux Shell 文本处理工具集锦【转】
    刷leetcode是什么样的体验?【转】
    知乎上的一些文章---leetcode【笔记1】
  • 原文地址:https://www.cnblogs.com/ddxxxb/p/6803193.html
Copyright © 2011-2022 走看看