龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 软件开发 > JAVA开发 >

使用TreeView实现无限级扩展节点

时间:2009-12-23 15:42来源:未知 作者:admin 点击:
分享到:
由于数据量很大,所以不能利用rs结果集一次读出,在往treeview节点上填充。 需要填充树型节点的字段内数据形式为以"."分割 如:01 01.01 01.02 01.01.01 02 02.01 02.01 ............................ 利

  由于数据量很大,所以不能利用rs结果集一次读出,在往treeview节点上填充。
  
  需要填充树型节点的字段内数据形式为以"."分割
  
  如:01  01.01 01.02 01.01.01 02 02.01 02.01 ............................
  
  利用Oracle自身instr函数,可以按"."数分割。并返回所需要的结果集,初始化加载读取不带"."字段,第一次读取带一个"."…………
  
  至于sqlserver数据库与oracle的函数书写略有不同,可以到Google,csdn等地方去查找。
  
  sql语句的大致写法如下:
  
  If pDotCount = 0 Then
  sqlString = "select t.需要分割的字段,t.cname from 表名 t where Instr(t.icsn, '.', 1, 1)=0"
  Else
  sqlString = "select t.需要分割的字段,t.cname from 表名 t where Instr(t.icsn, '.', 1," & pDotCount & ")>0 and Instr(t.icsn, '.', 1, " & (pDotCount + 1) & ")=0 and Instr(t.icsn,'" & pParent & "',1,1)=1"
  End If
  
  pDotCount为需要读取的字段中"."的个数
  
  然后通过双击事件获得父节点(即为选中节点),sql语句中pParent,返回属于该父节点的子节点,这样一级一级双击即可实现无限扩展,直至走到数据最后一层为止
  
  检索定位任一节点
  
  主要是在于初始选择节点的定位。此处略去,如有爱好,可以直接和我联系,互相学习。
  
精彩图集

赞助商链接