Foxtable(狐表)用户栏目专家坐堂 → 关于筛选树


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

主题:关于筛选树

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


加好友 发短信
等级:童狐 帖子:213 积分:2237 威望:0 精华:0 注册:2012/9/3 16:21:00
关于筛选树  发帖心情 Post By:2013/8/25 2:49:00 [只看该作者]

筛选树需要有两个筛选功能,分别是员工业绩筛选, 和 折扣分类筛选, 现在设计了对应的l两个按钮双击生成筛选树,试问, 按钮做了两个,那筛选树我是需要放一颗还是两颗了?如只需要一棵筛选树,那代码是如何变化了?我用的是如下代码:

 

 

员工业绩按钮代码:

Dim cmd As New SQLCommand
Dim dt As DataTable
cmd.CommandText = "SELECT DISTINCT year(销售日期) as 年份,Month(销售日期) As 月份, 工作人员 From {销售表}"
dt = cmd.ExecuteReader()
Dim trv As WinForm.TreeView = e.Form.Controls("TreeView1")
trv.BuildTree(dt,"年份|月份|工作人员")
trv.Nodes.Insert("销售人员业绩(按月核算)",0)

 

折扣业绩按钮代码:

Dim cmd As New SQLCommand
Dim dt As DataTable
cmd.CommandText = "SELECT DISTINCT year(销售日期) as 年份,Month(销售日期) As 月份, 折扣 From {销售表}"
dt = cmd.ExecuteReader()
Dim trv As WinForm.TreeView = e.Form.Controls("TreeView1")
trv.BuildTree(dt,"年份|月份|折扣")
trv.Nodes.Insert("折扣业绩核算(按月核算)",0)

 

业绩查询代码(功能已经实现)

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 & "#"
    Case 2
        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 & "# And 工作人员 = '" & Value(2) & "'"
End Select
Tables("托管结算_托管结算").Filter = Filter

 

望指教!


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


加好友 发短信
等级:狐神 帖子:4752 积分:34568 威望:0 精华:0 注册:2008/8/31 22:44:00
  发帖心情 Post By:2013/8/25 6:05:00 [只看该作者]

用一个筛选树
不同的地方用全局变量处理一下就可以了
如果做不成可以上传个例子的

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


加好友 发短信
等级:版主 帖子:5246 积分:33163 威望:0 精华:8 注册:2013/1/17 21:28:00
  发帖心情 Post By:2013/8/25 7:40:00 [只看该作者]

这是简单的选择:

一个目录树控件,根据不同的生成条件,可以生成无数个目录树。

If e.Sender.AllNodes(0).Name = "销售人员业绩(按月核算)" Then

   '业绩查询代码

ElseIf e.Sender.AllNodes(0).Name = "折扣业绩核算(按月核算)" Then

   '折扣业绩查询代码

Else

   '.......

End If


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


加好友 发短信
等级:狐神 帖子:4752 积分:34568 威望:0 精华:0 注册:2008/8/31 22:44:00
  发帖心情 Post By:2013/8/25 12:24:00 [只看该作者]

上面确实简单,虽然代码会多很多

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


加好友 发短信
等级:童狐 帖子:213 积分:2237 威望:0 精华:0 注册:2012/9/3 16:21:00
  发帖心情 Post By:2013/8/25 19:43:00 [只看该作者]

请问这个全局变量如何处理,望指教.


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


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2013/8/25 19:57:00 [只看该作者]

以下是引用owenlyx在2013-8-25 19:43:00的发言:

请问这个全局变量如何处理,望指教.


先按照3楼的方法实现先。如果要改进,可以自定义筛选,筛选代码可以不需要一个一个选。


 回到顶部