使用TreeView实现无限级扩展节点(原创)

[入库:2005年8月18日] [更新:2007年3月24日]

本文简介:选择自 yun15291li 的 blog

功能实现要求:

操作环境vb.net和oracle9i

 

由于数据量很大,所以不能利用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,返回属于该父节点的子节点,这样一级一级双击即可实现无限扩展,直至走到数据最后一层为止

检索定位任一节点

主要是在于初始选择节点的定位。此处略去,如有兴趣,可以直接和我联系,互相学习。

 

msn:yun15291li@hotmail.com

email:ygyunguang@yahoo.com.cn

本文关键:使用TreeView实现无限级扩展节点(原创)
  相关方案
Google
 

本站最佳浏览方式为 分辨率 1024x768 IE 6.0(或更高版本的 IE浏览器)

go top