Foxtable(狐表)用户栏目专家坐堂 → 请教,目录树貌能否只对加载列进行建树?


  共有4925人关注过本帖树形打印复制链接

主题:请教,目录树貌能否只对加载列进行建树?

帅哥哟,离线,有人找我吗?
everybody
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:小狐 帖子:307 积分:2252 威望:0 精华:0 注册:2013/2/28 9:05:00
请教,目录树貌能否只对加载列进行建树?  发帖心情 Post By:2013/6/13 13:14:00 [只看该作者]

按老大教导,重新把问题描述一下。

一、目标:目录树只对加载出来的列进行建树和筛选

二、先说我怎么干的图片点击可在新窗口打开查看

1、在窗口加载时,按自定义的 _UserOffice 进行加载;同时生成目录树treeview1(估计就是这里错了)

'加载本部门数据
With DataTables("收文")
    .LoadFilter = "" '设置加载条件
    .LoadFilter = "办文单位 = '" & _UserOffice  & "'"
    .LoadPage = 0 '加载第一页
    .LoadTop = 20 '每页20行
    .Load()
    e.Form.Controls("TextBox4").Value = 1 & "/" & .TotalPages
End With

'生成目录树
Dim cmd As New SQLCommand
Dim dt As DataTable
cmd.C
cmd.CommandText = "SELECT DISTINCT Year(收文日期) As 年, Month(收文日期) As 月 From {收文}"
dt = cmd.ExecuteReader()
Dim trv As WinForm.TreeView = e.Form.Controls("TreeView1")
trv.BuildTree(dt, "年|月")


2、在目录树nodemouseclick处,点击则筛选
Dim Value() As String
Dim Filter As String
Dim d1 As Date
Dim d2 As Date
Value = e.Node.FullPath.Split("\")
Select Case e.Node.Level
    Case 0
        Dim y As Integer = value(0)
        d1 = New Date(y,1,1) '取得该年的第一天
        d2 = new Date(y,12,31) '取得该年的最后一天
        Filter = "收文日期 >= #" & d1 & "# And 收文日期 <= #" & d2 & "#"
    Case 1
        Dim y As Integer = value(0)
        Dim m As Integer = value(1)
        d1 = New Date(y, m, 1) '取得该月的第一天
        d2 = new Date(y, m, Date.DaysInMonth(y,m)) '取得该月的最后一天
        Filter = "收文日期 >= #" & d1 & "# And 收文日期 <= #" & d2 & "#"
    
End Select
Tables("收文").Filter = Filter

三、图示更好理解

第一图,加载数据并生成目录树。。。

图片点击可在新窗口打开查看此主题相关图片如下:1.jpg
图片点击可在新窗口打开查看

第二图,注意,实际上2012年6月和2013年的3月数据,实际 _UserOffice 没有浏览权限,不应该出现这两个节点的。

图片点击可在新窗口打开查看此主题相关图片如下:2.jpg
图片点击可在新窗口打开查看


何故?个人认为应该是目录树生成公示错了
[此贴子已经被作者于2013-6-13 13:46:15编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
everybody
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:小狐 帖子:307 积分:2252 威望:0 精华:0 注册:2013/2/28 9:05:00
  发帖心情 Post By:2013/6/13 13:15:00 [只看该作者]

这个例子还不好做哦,等一下拍个录像吧。。

 回到顶部
帅哥哟,离线,有人找我吗?
狐狸爸爸
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:47497 积分:251403 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2013/6/13 13:16:00 [只看该作者]

呵呵,有具体的问题,才有具体答案,你这样提问,让人从何说起啊?

最好用个简单例子说明你的问题,至少也的贴出你的代码,然后说明代码的目的和问题。

 

图片点击可在新窗口打开查看

 

 


 回到顶部
帅哥哟,离线,有人找我吗?
everybody
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:小狐 帖子:307 积分:2252 威望:0 精华:0 注册:2013/2/28 9:05:00
  发帖心情 Post By:2013/6/13 13:22:00 [只看该作者]

老总说的对,我去搞个细一点的版本过来说明

 回到顶部
帅哥哟,离线,有人找我吗?
狐狸爸爸
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:47497 积分:251403 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2013/6/13 14:23:00 [只看该作者]

1、生成目录树:
Dim cmd As New SQLCommand
Dim dt As DataTable
cmd.C
cmd.CommandText = "SELECT DISTINCT Year(收文日期) As 年, Month(收文日期) As 月 From {收文} Where 办文单位 = '" & _UserOffice  & "'"
dt = cmd.ExecuteReader()
Dim trv As WinForm.TreeView = e.Form.Controls("TreeView1")
trv.BuildTree(dt, "年|月")
 
2、加载数据:
 
 
Dim Value() As String
Dim Filter As String
Dim d1 As Date
Dim d2 As Date
Value = e.Node.FullPath.Split("\")
Select Case e.Node.Level
    Case 0
        Dim y As Integer = value(0)
        d1 = New Date(y,1,1) '取得该年的第一天
        d2 = new Date(y,12,31) '取得该年的最后一天
        Filter = "收文日期 >= #" & d1 & "# And 收文日期 <= #" & d2 & "#"
    Case 1
        Dim y As Integer = value(0)
        Dim m As Integer = value(1)
        d1 = New Date(y, m, 1) '取得该月的第一天
        d2 = new Date(y, m, Date.DaysInMonth(y,m)) '取得该月的最后一天
        Filter = "收文日期 >= #" & d1 & "# And 收文日期 <= #" & d2 & "#"
End Select
if Filter = "" then
    Filter = "办文单位 = '" & _UserOffice  & "'"
else
    Filter = "(" & Filter & ") And 办文单位 = '" & _UserOffice  & "'"
End If
Tables("收文").Filter = Filter

 回到顶部
帅哥哟,离线,有人找我吗?
傻马难骑
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:童狐 帖子:215 积分:1306 威望:0 精华:0 注册:2013/4/7 22:24:00
  发帖心情 Post By:2013/6/13 14:25:00 [只看该作者]

没能看明白图片点击可在新窗口打开查看


 回到顶部
帅哥哟,离线,有人找我吗?
everybody
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:小狐 帖子:307 积分:2252 威望:0 精华:0 注册:2013/2/28 9:05:00
  发帖心情 Post By:2013/6/13 14:40:00 [只看该作者]

呵呵,明白,谢谢老乡

 回到顶部