Foxtable(狐表)用户栏目专家坐堂 → 统计表怎样这样计算?


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

主题:统计表怎样这样计算?

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


加好友 发短信
等级:童狐 帖子:245 积分:3629 威望:0 精华:1 注册:2010/5/9 18:45:00
统计表怎样这样计算?  发帖心情 Post By:2011/12/11 17:16:00 [只看该作者]

例:在组合多个统计结果使用中,统计表窗口需要增加一列上期库存,也就是统计(小于开始日期进货单 减去 小于开始日期销售单 减去 小于开始日期退货单结果),现在是统计出来数据怎样写代码组合到表中

 

 

还有统计表按键代码ISNULL表达式在为空的情况下为什么不为0呀?也设置了表达式呀?ISNULL([进货_数量],0) - ISNULL([销售_数量],0) - ISNULL([退货_数量],0)

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:管理项目1.table

窗口在统计表中

[此贴子已经被作者于2011-12-11 18:16:38编辑过]

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


加好友 发短信
等级:管理员 帖子:47497 积分:251403 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2011/12/11 20:41:00 [只看该作者]

索性手工编码进行统计算了, 也不难的:

 

http://www.foxtable.com/help/topics/0681.htm

 


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


加好友 发短信
等级:童狐 帖子:245 积分:3629 威望:0 精华:1 注册:2010/5/9 18:45:00
  发帖心情 Post By:2011/12/12 10:44:00 [只看该作者]

手工编码能不能统计后台数据,如果要加载全部单据就不行了,不过为了学习好狐表,还是想看看统计是怎样用代码设计变通的!


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


加好友 发短信
等级:管理员 帖子:47497 积分:251403 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2011/12/12 11:59:00 [只看该作者]

Dim bd1 As New SQLGroupTableBuilder("统计表1","进货单")
Dim dt1 As fxDataSource
bd1.Groups.AddDef("型号") '根据型号分组
bd1.Totals.AddDef("数量","进货_数量") '对数量进行统计
bd1.Totals.AddExp("进货_金额","数量 * 单价") '对金额进行统计
bd1.Filter = "[日期] >= #" & Vars("开始日期") & "# And [日期] <= #" & Vars("结束日期") & "#"
dt1 = bd1.BuildDataSource()

Dim bd2 As New SQLGroupTableBuilder("统计表2","销售单")
Dim dt2 As fxDataSource
bd2.Groups.AddDef("型号") '根据型号分组
bd2.Totals.AddDef("数量","销售_数量") '对数量进行统计
bd2.Totals.AddExp("销售_金额","数量 * 售价") '对金额进行统计
bd2.Filter = "[日期] >= #" & Vars("开始日期") & "# And [日期] <= #" & Vars("结束日期") & "#"
dt2 = bd2.BuildDataSource()

Dim bd3 As New SQLGroupTableBuilder("统计表3","退货单")
Dim dt3 As fxDataSource
bd3.Groups.AddDef("型号") '根据型号分组
bd3.Totals.AddDef("数量","退货_数量") '对数量进行统计
bd3.Totals.AddExp("退货_金额","数量 * 单价") '对金额进行统计
bd3.Filter = "[日期] >= #" & Vars("开始日期") & "# And [日期] <= #" & Vars("结束日期") & "#"
dt3 = bd3.BuildDataSource()

Dim bd4 As New SQLGroupTableBuilder("统计表1","进货单")
Dim dt4 As fxDataSource
bd4.Groups.AddDef("型号") '根据型号分组
bd4.Totals.AddDef("数量","上期_进货_数量") '对数量进行统计
bd4.Totals.AddExp("上期_进货_金额","数量 * 单价") '对金额进行统计
bd4.Filter = "[日期] < #" & Vars("开始日期") & "#"
dt4 = bd4.BuildDataSource()

Dim bd5 As New SQLGroupTableBuilder("统计表2","销售单")
Dim dt5 As fxDataSource
bd5.Groups.AddDef("型号") '根据型号分组
bd5.Totals.AddDef("数量","上期_销售_数量") '对数量进行统计
bd5.Totals.AddExp("上期_销售_金额","数量 * 售价") '对金额进行统计
bd5.Filter = "[日期] < #" & Vars("开始日期") & "#"
dt5 = bd5.BuildDataSource()

Dim bd6 As New SQLGroupTableBuilder("统计表3","退货单")
Dim dt6 As fxDataSource
bd6.Groups.AddDef("型号") '根据型号分组
bd6.Totals.AddDef("数量","上期_退货_数量") '对数量进行统计
bd6.Totals.AddExp("上期_退货_金额","数量 * 单价") '对金额进行统计
bd6.Filter = "[日期] < #" & Vars("开始日期") & "#"
dt6 = bd6.BuildDataSource()

dt1.Combine("型号",dt2,"型号") '将销售统计数据组合到进货统计数据
dt1.Combine("型号",dt3,"型号") '将退货统计数据组合到进货统计数据
dt1.Combine("型号",dt4,"型号") '将退货统计数据组合到进货统计数据
dt1.Combine("型号",dt5,"型号") '将退货统计数据组合到进货统计数据
dt1.Combine("型号",dt6,"型号") '将退货统计数据组合到进货统计数据
Tables("窗口3_Table1").DataSource = dt1 '将统计结果绑定到Table
With DataTables("窗口3_Table1").DataCols  '用表达式列计算库存数据
    .Add("库存_数量",Gettype(Integer), "ISNULL([进货_数量],0) - ISNULL([销售_数量],0) - ISNULL([退货_数量],0)")
    .Add("库存_金额",Gettype(Double), "[库存_数量] /[进货_数量] * [进货_金额]")
    .Add("上期库存_数量",Gettype(Integer), "ISNULL([上期_进货_数量],0) - ISNULL([上期_销售_数量],0) - ISNULL([上期_退货_数量],0)")
    .Add("上期库存_金额",Gettype(Double),"[上期库存_数量] /[上期_进货_数量] * [上期_进货_金额]")
End With


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


加好友 发短信
等级:童狐 帖子:245 积分:3629 威望:0 精华:1 注册:2010/5/9 18:45:00
  发帖心情 Post By:2011/12/12 13:19:00 [只看该作者]

目的是达到了,遗憾就是增加了几列过度列,需要在统计后隐藏排序,我这张统计表共要统计20多列数据,如果加上过度列,估计要统计30多次,有点晕头
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:管理项目1.table

[此贴子已经被作者于2011-12-12 13:21:53编辑过]

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


加好友 发短信
等级:管理员 帖子:47497 积分:251403 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2011/12/12 13:40:00 [只看该作者]

你可以用代码删除多余的列。

 回到顶部