以文本方式查看主题 - Foxtable(狐表) (http://www.foxtable.com/bbs/index.asp) -- 专家坐堂 (http://www.foxtable.com/bbs/list.asp?boardid=2) ---- 加载树代码编写错误 (http://www.foxtable.com/bbs/dispbbs.asp?boardid=2&id=105361) |
-- 作者:动检 -- 发布时间:2017/8/17 17:17:00 -- 加载树代码编写错误 想让各位大神帮看看代码哪里出错了 提示说“至少一个参数没有被指定值”。而且年月日的排布也不对,想生成的加载树逐级关系是:送检单位,年份,月份,日 窗口代码 Dim dt As DataTable Dim b As New SQLGroupTableBuilder("统计表1","检测样品登记") b.Groups.AddDef("送检单位") b.Groups.AddDef("送检日期",DateGroupEnum.Year,"年") b.Groups.AddDef("送检日期",DateGroupEnum.Month,"月") b.Groups.AddDef("送检日期",DateGroupEnum.Day,"日") b.Totals.AddDef("_Identify",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 Product As String = nd.DataRow("送检单位") Dim Year As Integer = nd.DataRow("年") Dim Month As Integer = nd.DataRow("月") Dim Day As Integer = 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 & "日(" & dt.Compute("Sum(样品数量)","年 = " & Year & " And 月 = " & Month & " And 日 = " & Day) & "条)" Case 3 nd.Text = nd.text & "(" & nd.DataRow("样品数量") & ")" End Select Next trv.Nodes.Insert("加载所有行","加载所有行(" & dt.Compute("Sum(样品数量)") & "条)",0) trv.ResumeRedraw 窗口下加载树的代码 Dim Filter As String = ""
If e.Node.Name <> "加载所有行" Then \'要用Name属性,不能用Text属性 Dim Product As String = e.Node.DataRow("送检单位") Dim Year As Integer = e.Node.DataRow("年") Dim Month As Integer = e.Node.DataRow("月") Dim Day As Integer = e.Node.DataRow("日") Select Case e.Node.Level Case 0 Filter ="Product(送检单位) = " Case 1 Filter ="Year(检测日期) = " & Year Case 2 Filter ="Year(检测日期) = " & Year & " And Month(检测日期) = " & Month Case 3 Filter ="Year(检测日期) = " & Year & " And Month(检测日期) = " & Year & " And Day(检测日期) = " & Day Case 4 Filter ="Year(检测日期) = " & Year & " And Month(检测日期) = " & Year & " And Day(检测日期) " & Day & " And 送检单位 = \'" & Product & "\'" End Select End If DataTables("检测样品登记").LoadFilter = Filter DataTables("检测样品登记").Load() |
-- 作者:有点甜 -- 发布时间:2017/8/17 18:01:00 -- Dim b As New SQLGroupTableBuilder("统计表1","检测样品登记")
-------------------------
Dim Filter As String = "" |
-- 作者:动检 -- 发布时间:2017/9/18 15:20:00 -- 谢谢 |