以文本方式查看主题

-  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=12567)

--  作者:7032175
--  发布时间:2011/9/7 14:07:00
--  组合多个统计结果(加表加不进去)

 

Dim bd1 As New GroupTableBuilder("统计表1",DataTables("进货单"))

Dim dt1 As fxDataSource

bd1.Groups.AddDef("品名") \'根据品名分组

bd1.Groups.AddDef("型号") \'根据型号分组

bd1.Totals.AddDef("数量","进货_数量") \'对数量进行统计

bd1.Totals.AddDef("金额","进货_金额") \'对金额进行统计

dt1 = bd1.BuildDataSource()

 

Dim bd2 As New GroupTableBuilder("统计表2",DataTables("销售单"))

Dim dt2  As fxDataSource

bd2.Groups.AddDef("品名") \'根据品名分组

bd2.Groups.AddDef("型号") \'根据型号分组

bd2.Totals.AddDef("数量","销售_数量") \'对数量进行统计

bd2.Totals.AddDef("金额","销售_金额") \'对金额进行统计

dt2 = bd2.BuildDataSource()

 

Dim bd3 As New GroupTableBuilder("统计表3",DataTables("退货单"))

Dim dt3 As fxDataSource

bd3.Groups.AddDef("品名") \'根据品名分组

bd3.Groups.AddDef("型号") \'根据型号分组

bd3.Totals.AddDef("数量","退货_数量") \'对数量进行统计

bd3.Totals.AddDef("金额","退货_金额") \'对金额进行统计

dt3 = bd3.BuildDataSource()

 

Dim nms As String() = {"品名","型号"} \'指定连接列

dt1.Combine(nms,dt2,nms) \'将销售统计数据组合到进货统计数据

dt1.Combine(nms,dt3,nms) \'将退货统计数据组合到进货统计数据

Tables("窗口1_Table1").DataSource = dt1 \'将统计结果绑定到Table

 

 

 

我在加进一个表示例是这样子的:

 

Dim bd1 As New GroupTableBuilder("统计表1",DataTables("进货单"))

Dim dt1 As fxDataSource

bd1.Groups.AddDef("品名") \'根据品名分组

bd1.Groups.AddDef("型号") \'根据型号分组

bd1.Totals.AddDef("数量","进货_数量") \'对数量进行统计

bd1.Totals.AddDef("金额","进货_金额") \'对金额进行统计

dt1 = bd1.BuildDataSource()

 

Dim bd2 As New GroupTableBuilder("统计表2",DataTables("销售单"))

Dim dt2  As fxDataSource

bd2.Groups.AddDef("品名") \'根据品名分组

bd2.Groups.AddDef("型号") \'根据型号分组

bd2.Totals.AddDef("数量","销售_数量") \'对数量进行统计

bd2.Totals.AddDef("金额","销售_金额") \'对金额进行统计

dt2 = bd2.BuildDataSource()

 

Dim bd3 As New GroupTableBuilder("统计表3",DataTables("退货单"))

Dim dt3 As fxDataSource

bd3.Groups.AddDef("品名") \'根据品名分组

bd3.Groups.AddDef("型号") \'根据型号分组

bd3.Totals.AddDef("数量","退货_数量") \'对数量进行统计

bd3.Totals.AddDef("金额","退货_金额") \'对金额进行统计

dt3 = bd3.BuildDataSource()

 

Dim bd4 As New GroupTableBuilder("统计表4",DataTables("货单"))

Dim dt4 As fxDataSource

bd4.Groups.AddDef("品名") \'根据品名分组

bd4.Groups.AddDef("型号") \'根据型号分组

bd4.Totals.AddDef("数量","退货_数量") \'对数量进行统计

bd4.Totals.AddDef("金额","退货_金额") \'对金额进行统计

dt4 = bd4.BuildDataSource()

 

Dim nms As String() = {"品名","型号"} \'指定连接列

dt1.Combine(nms,dt2,nms) \'将销售统计数据组合到进货统计数据

dt1.Combine(nms,dt3,nms) \'将退货统计数据组合到进货统计数据

dt1.Combine(nms,dt4,nms) \'将退货统计数据组合到进货统计数据

Tables("窗口1_Table1").DataSource = dt1 \'将统计结果绑定到Table

 

 通过这样的加法但是执行的时候是错误的为什么?


--  作者:狐狸爸爸
--  发布时间:2011/9/7 14:18:00
--  
做个例子上来,才好判断。
--  作者:7032175
--  发布时间:2011/9/7 14:41:00
--  
在合同信息里面  狐爸爸
--  作者:狐狸爸爸
--  发布时间:2011/9/7 14:42:00
--  
你的文件在哪里?
--  作者:don
--  发布时间:2011/9/7 15:17:00
--  

bd3与bd4存在同名列当然不行!

..........

bd3.Totals.AddDef("数量","退货_数量") \'对数量进行统计

bd3.Totals.AddDef("金额","退货_金额") \'对金额进行统计


..........

bd4.Totals.AddDef("数量","退货_数量") \'对数量进行统计

bd4.Totals.AddDef("金额","退货_金额") \'对金额进行统计


--  作者:7032175
--  发布时间:2011/9/7 16:43:00
--  在合同信息里
在合同信息里
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:唐龙设计生产管理系统.table


--  作者:狐狸爸爸
--  发布时间:2011/9/7 16:52:00
--  
5楼的don已经告诉你原因了,你自己修正一下代码吧。
--  作者:don
--  发布时间:2011/9/7 17:09:00
--  
 其它表的[计划号]长度() < 成品表的[计划号]的MaxLength ,当然无法组合
[此贴子已经被作者于2011-9-7 17:14:38编辑过]

--  作者:7032175
--  发布时间:2011/9/8 7:46:00
--  组合多少个表(多加一个表不行)
这是个原件昨天提出来的问题5楼的不对还是请狐爸爸看一下
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:问题在合同信息里面.table


--  作者:紙上不談兵
--  发布时间:2011/9/8 8:09:00
--  
以下是引用7032175在2011-9-8 7:46:00的发言:
这是个原件昨天提出来的问题5楼的不对还是请狐爸爸看一下
 下载信息  [文件大小:940.0 KB  下载次数:2]
图片点击可在新窗口打开查看点击浏览该文件:问题在合同信息里面.table

-------------------------------------------------------------------------
晕!8楼不是告知你原因吗:其它表计划号长度都是10,
而成品表计划号的[10209 10319]的长度是11,超出10,只要把所有的
计划号长度都设置为16即可!

[此贴子已经被作者于2011-9-8 8:38:22编辑过]