功能实现要求:
操作环境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