以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  筛选树不能更新数据  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=59855)

--  作者:seintfei
--  发布时间:2014/11/12 12:58:00
--  筛选树不能更新数据
“在筛选树显示统计数据”根据帮助文件做的筛选树不能更新数据

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

增加了一行后,筛选树的统计没更新(统计表1没有更新),代码如下,请问如何修改

Dim dt As DataTable
Dim b As New GroupTableBuilder("统计表1",DataTables("报价进度管理"))
b.Groups.AddDef("依赖日期",DateGroupEnum.Year,"年")
b.Groups.AddDef("依赖日期",DateGroupEnum.Month,"月")
b.Groups.AddDef("客户")
b.Totals.AddDef("项目号",AggregateEnum.Count,"订单数") \'根据客户列来统计记录数,也就是订单数
dt = b.Build(False) \'参数设置为False,生成一个临时表,不在主界面显示
\'然后根据统计表生成目录树
Dim trv As WinForm.TreeView = e.Form.Controls("TreeView1")
trv.BuildTree(dt, "年|月|客户")
trv.StopRedraw
For Each nd As WinForm.TreeNode In trv.AllNodes
    Dim Year As Integer = nd.DataRow("年")
    Dim Month As Integer = nd.DataRow("月")
    Dim Product As String = nd.DataRow("客户")
    Select Case nd.Level
        Case 0
            nd.Text = nd.text & "年(" & dt.Compute("Sum(订单数)","年 = " & Year) & "单)"
        Case 1
            nd.Text = nd.text & "月(" & dt.Compute("Sum(订单数)","年 = " & Year & " And 月 = " & Month) & "单)"
        Case 2
            nd.Text = nd.text & "(" & nd.DataRow("订单数") & "单)"
    End Select
Next
trv.Nodes.Insert("显示所有行","显示所有行(" & dt.Compute("Sum(订单数)") & "单)",0)
trv.ResumeRedraw

[此贴子已经被作者于2014-11-12 13:52:16编辑过]

--  作者:jialihaha
--  发布时间:2014/11/12 13:41:00
--  
看不懂什么意思,截图详细说说
--  作者:jialihaha
--  发布时间:2014/11/12 13:51:00
--  
重新刷新一下筛选树呗
--  作者:有点甜
--  发布时间:2014/11/12 14:17:00
--  
 修改数据或者新增数据以后,要重新生成一次筛选树
--  作者:seintfei
--  发布时间:2014/11/12 15:07:00
--  
请帮忙改下代码,谢谢
--  作者:有点甜
--  发布时间:2014/11/12 15:10:00
--  
以下是引用seintfei在2014-11-12 15:07:00的发言:
请帮忙改下代码,谢谢

 

就是做一个刷新按钮,拷贝生成的代码,重新生成一次啊


--  作者:jialihaha
--  发布时间:2014/11/12 15:12:00
--  

OpenFilterTree(ColNames, Size)

ColNames:指定分组列,不同的列之间用符号"|"隔开,例如“产品|客户”
Size:    可选参数,指定筛选树的宽度,如果左停靠区已经有窗口停靠,则此参数无效。