Rss & SiteMap
Foxtable(狐表) http://www.foxtable.com
帮助文件里跳过统计表有这么一行代码:
Series.Y(i) = tbl.Compute("Sum(数量)","[产品] = '" & lst(i) & "'") '指定垂直坐标
这个如何在后台统计,不用生成统计表。有这个功能是更好。
帮助文件里跳过统计表有这么一行代码:
Series.Y(i) = tbl.Compute("Sum(数量)","[产品] = '" & lst(i) & "'") '指定垂直坐标
这个如何在后台统计,不用生成统计表。有这个功能是更好。
没有看明白你的意思,上面的代码本来就没有生成统计表
此外CrossTableBuilder、CrossTableBuilder都可以生成一个临时的DataTable供代码调用,不显示Table,只需给Build加上一个参数True即可。
Dim chart As WinForm.chart
e.form.RemoveControl("chart1")
chart = e.Form.CreateControl("chart1", ControlTypeEnum.chart)
e.Form.AddControl(chart)
e.form.controls("chart1").width=400
Dim Series As WinForm.ChartSeries '定义一个图系变量
Dim tbl As DataTable = DataTables("商品单明细") '定义一个变量tbl引用数据表
Dim lst As List(Of String) = tbl.GetUniqueValues("", "商品编号") '获得商品编号名称集合
Chart = e.Form.Controls("Chart1") ' 引用窗口中的图表
Chart.ChartType = ChartTypeEnum.Bar '图表类型该为Bar(条形)
Chart.SeriesList.Clear() '清除图表原来的图系
Series = Chart.SeriesList.Add() '增加一个图系
Series.Length = lst.Count '设置图系的长度
For i As integer = 0 to lst.Count - 1 '指定每个数据点的位置
Series.X(i) = i '指定水平坐标
Series.Y(i) = tbl.Compute("Sum(暂估_应收款)","[商品编号] = '" & lst(i) & "'")- tbl.Compute("Sum(出库_金额)","[商品编号] = '" & lst(i) & "'") '指定垂直坐标
Chart.AxisX.SetValueLabel(i, lst(i)) '指定字符表示
Next
Chart.AxisY.Min = 0 '指定Y轴的最小值
Chart.AxisX.AnnoWithLabels = True '启用字符标示
Series.DataLabelText = "{#YVAL}"
Chart.HeaderText="按商品编号分类订单利润"
贴段帮助给你看看
为此GroupTableBuilder和CrossTableBuilder都提供了一个名为FromServer的逻辑属性,只需将此属性设为True,即可直接统计后台数据。
例如:
Dim
g As New GroupTableBuilder("统计表1", DataTables("订单"))