Foxtable(狐表)用户栏目专家坐堂 → [求助]汇总


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

主题:[求助]汇总

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


加好友 发短信
等级:五尾狐 帖子:1014 积分:6757 威望:0 精华:0 注册:2014/2/12 20:14:00
[求助]汇总  发帖心情 Post By:2014/8/14 16:24:00 [只看该作者]

 下载信息  [文件大小:   下载次数: ]
点击浏览该文件:汇总.rar

With e.Form.Controls("日期")
    If .Value Is Nothing Then
        Return
    End If
End With
Tables("统计_Table1").StopRedraw
Dim Filter As String
Dim curD As Date=e.Form.Controls("日期").Value '当前日期
Dim lastD As Date = curD.AddMonths(-1) '上一个月的日期
Dim lastD2 As New Date(lastD.Year, lastD.Month, Date.DaysInMonth(lastD.Year,lastD.Month)) '上个月的最后一天
Filter = Filter &  "日期 > #" & lastD2 & "#" & " And 日期  <= #" & curD & "#"

Dim bd1 As New SQLGroupTableBuilder("统计表1","入库明细")
Dim dt1 As fxDataSource
bd1.Groups.AddDef("规格") '根据型号分组
bd1.Totals.AddDef("入库数量","入库_数量") '对数量进行统计
bd1.Totals.AddDef("价税合计","入库_金额") '对金额进行统计
bd1.Filter = Filter
dt1 = bd1.BuildDataSource()

Dim bd2 As New SQLGroupTableBuilder("统计表2","出库明细")
Dim dt2  As fxDataSource
bd2.Groups.AddDef("规格") '根据规格分组
bd2.Totals.AddDef("出库数量","销售_数量") '对数量进行统计
bd2.Totals.AddDef("价税合计","销售_金额") '对金额进行统计
bd2.Filter = Filter
dt2 = bd2.BuildDataSource()

Dim bd3 As New SQLGroupTableBuilder("统计表3","退货")
Dim dt3 As fxDataSource
bd3.Groups.AddDef("规格") '根据规格分组
bd3.Totals.AddDef("退货_数量","退货_数量") '对数量进行统计
bd3.Totals.AddDef("退货_金额","退货_金额") '对金额进行统计
bd3.Filter = Filter
dt3 = bd3.BuildDataSource()

dt1.Combine("规格",dt2,"规格") '将销售统计数据组合到进货统计数据
dt1.Combine("规格",dt3,"规格") '将退货统计数据组合到进货统计数据
Tables("统计_Table1").DataSource = dt1 '将统计结果绑定到Table

With DataTables("统计_Table1").DataCols  '用表达式列计算库存数据
    .Add("期初_数量",Gettype(Double),"","期初_数量")
    .Add("期初_金额",Gettype(Double),"","期初_金额")
End With

Filter = "日期 <=  #" & lastD2 & "#"
Dim dt_jh As DataTable
Dim dt_xs As DataTable
Dim dt_th As DataTable
Dim cmd As new SQLCommand
cmd.CommandText = "select * from {入库明细} where " & Filter
dt_jh = cmd.ExecuteReader
cmd.CommandText = "select * from {出库明细} where " & Filter
dt_xs = cmd.ExecuteReader
cmd.CommandText = "select * from {退货} where " & Filter
dt_th = cmd.ExecuteReader

For Each r As Row In Tables("统计_Table1").Rows   
    Filter = "规格 = '" & r("规格") & "'"
    r("期初_数量") = dt_jh.Compute("sum(入库数量)", filter) - dt_xs.Compute("sum(出库数量)", filter) - dt_th.Compute("sum(退货_数量)", filter)
    r("期初_金额") = dt_jh.Compute("sum(价税合计)", filter) - dt_xs.Compute("sum(价税合计)", filter) - dt_th.Compute("sum(退货_金额)", filter)
Next
With DataTables("统计_Table1").DataCols  '用表达式列计算库存数据
    .Add("库存_数量",Gettype(Double), "IsNull([期初_数量],0) + IsNull([入库数量],0) - ISNULL([入库数量],0) - ISNULL([退货_数量],0)","库存_数量")
    .Add("库存_金额",Gettype(Double), "IsNull([期初_金额],0) + IsNull([价税合计],0) - ISNULL([价税合计],0) - ISNULL([退货_金额],0)","库存_金额")
End With

DataTables("统计_Table1").DataCols.Add("进货_单价", Gettype(Double), "(期初_金额+进货_金额)/(期初_数量+进货_数量)")

Tables("统计_Table1").SetColVisibleWidth("型号|80|期初_数量|80|期初_金额|80|进货_单价|80|进货_数量|80|进货_金额|80|销售_数量|80|销售_金额|80|退货_数量|80|退货_金额|80|库存_数量|80|库存_金额|80")

Tables("统计_Table1").DefaultRowHeight = 35
DataTables("统计_Table1").DataCols("期初_数量").SetFormat("#,###.00")
DataTables("统计_Table1").DataCols("期初_金额").SetFormat("#,###.00")
DataTables("统计_Table1").DataCols("进货_数量").SetFormat("#,###.00")
DataTables("统计_Table1").DataCols("进货_金额").SetFormat("#,###.00")
DataTables("统计_Table1").DataCols("销售_数量").SetFormat("#,###.00")
DataTables("统计_Table1").DataCols("销售_金额").SetFormat("#,###.00")
DataTables("统计_Table1").DataCols("退货_数量").SetFormat("#,###.00")
DataTables("统计_Table1").DataCols("退货_金额").SetFormat("#,###.00")
DataTables("统计_Table1").DataCols("库存_数量").SetFormat("#,###.00")
DataTables("统计_Table1").DataCols("库存_金额").SetFormat("#,###.00")
Tables("统计_Table1").ResumeRedraw

 

 

 

老师,我要在窗口搞个临时汇总表是通过按钮筛选出每个时段4表的情况。上面的代码是搬来的我该不好。望我最好的老师版主给我修改,


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


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2014/8/14 16:39:00 [只看该作者]

 做一个窗口,发上来。

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


加好友 发短信
等级:五尾狐 帖子:1014 积分:6757 威望:0 精华:0 注册:2014/2/12 20:14:00
  发帖心情 Post By:2014/8/14 17:32:00 [只看该作者]

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


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


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2014/8/14 18:23:00 [只看该作者]

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


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


加好友 发短信
等级:五尾狐 帖子:1014 积分:6757 威望:0 精华:0 注册:2014/2/12 20:14:00
  发帖心情 Post By:2014/8/14 20:23:00 [只看该作者]

老师,我输入的数据不汇总啊

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


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2014/8/14 20:26:00 [只看该作者]

以下是引用风声在2014-8-14 20:23:00的发言:
老师,我输入的数据不汇总啊

 

输入的数据,保存后才会汇总,汇总的时候,只汇总对应日期的数据。


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


加好友 发短信
等级:五尾狐 帖子:1014 积分:6757 威望:0 精华:0 注册:2014/2/12 20:14:00
  发帖心情 Post By:2014/8/14 20:35:00 [只看该作者]

当出库数量100的话期初数据出现负100

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


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2014/8/14 20:41:00 [只看该作者]

 代码

 

With e.Form.Controls("日期")
    If .Value Is Nothing Then
        Return
    End If
End With
Dim tname As String = "统计_Table1"
Tables(tname ).StopRedraw

Dim filter As String
Dim curD As Date=e.Form.Controls("日期").Value '当前日期
Dim lastD As Date = curD.AddMonths(-1) '上一个月的日期
Dim lastD2 As New Date(lastD.Year, lastD.Month, Date.DaysInMonth(lastD.Year,lastD.Month)) '上个月的最后一天

Dim bd1 As New SQLGroupTableBuilder("统计表1","入库明细")
Dim dt1 As fxDataSource
bd1.Groups.AddDef("规格") '根据型号分组
bd1.Totals.AddDef("入库数量","入库_数量") '对数量进行统计
bd1.Totals.AddDef("价税合计","入库_金额") '对金额进行统计
Dim Filter1 As String  = " 入库日期 > #" & lastD2 & "#" & " And 入库日期  <= #" & curD & "#"
bd1.Filter = Filter1
dt1 = bd1.BuildDataSource()

Dim bd2 As New SQLGroupTableBuilder("统计表2","出库明细")
Dim dt2  As fxDataSource
bd2.Groups.AddDef("规格") '根据规格分组
bd2.Totals.AddDef("出库数量","销售_数量") '对数量进行统计
bd2.Totals.AddDef("价税合计","销售_金额") '对金额进行统计
Dim Filter2 As String =  "出库日期 > #" & lastD2 & "#" & " And 出库日期  <= #" & curD & "#"
bd2.Filter = Filter2
dt2 = bd2.BuildDataSource()

Dim bd3 As New SQLGroupTableBuilder("统计表3","销售退货")
Dim dt3 As fxDataSource
bd3.Groups.AddDef("规格") '根据规格分组
bd3.Totals.AddDef("退货_数量","退货_数量") '对数量进行统计
bd3.Totals.AddDef("退货_金额","退货_金额") '对金额进行统计
Dim Filter3 As String =  "退货日期 > #" & lastD2 & "#" & " And 退货日期  <= #" & curD & "#"
bd3.Filter = Filter3
dt3 = bd3.BuildDataSource()
dt1.Combine("规格",dt2,"规格") '将销售统计数据组合到进货统计数据
dt1.Combine("规格",dt3,"规格") '将退货统计数据组合到进货统计数据
Tables(tname).DataSource = dt1 '将统计结果绑定到Table

With DataTables(tname).DataCols  '用表达式列计算库存数据
    .Add("期初_数量",Gettype(Double),"","期初_数量")
    .Add("期初_金额",Gettype(Double),"","期初_金额")
End With

Filter1 = "入库日期 <=  #" & lastD2 & "#"
Filter2 = "出库日期 <=  #" & lastD2 & "#"
Filter3 = "销售日期 <=  #" & lastD2 & "#"
Dim dt_jh As DataTable
Dim dt_xs As DataTable
Dim dt_th As DataTable
Dim cmd As new SQLCommand
cmd.CommandText = "select * from {入库明细} where " & Filter1
dt_jh = cmd.ExecuteReader
cmd.CommandText = "select * from {出库明细} where " & Filter2
dt_xs = cmd.ExecuteReader
cmd.CommandText = "select * from {销售退货} where " & Filter3
dt_th = cmd.ExecuteReader

For Each r As Row In Tables(tname).Rows   
    Filter = "规格 = '" & r("规格") & "'"
    r("期初_数量") = dt_jh.Compute("sum(入库数量)", filter) - dt_xs.Compute("sum(出库数量)", filter) - dt_th.Compute("sum(退货_数量)", filter)
    r("期初_金额") = dt_jh.Compute("sum(价税合计)", filter) - dt_xs.Compute("sum(价税合计)", filter) - dt_th.Compute("sum(退货_金额)", filter)
Next

With DataTables(tname).DataCols  '用表达式列计算库存数据
    .Add("库存_数量",Gettype(Double), "IsNull([期初_数量],0) + IsNull([入库_数量],0) - ISNULL([销售_数量],0) - ISNULL([退货_数量],0)","库存_数量")
    .Add("库存_金额",Gettype(Double), "IsNull([期初_金额],0) + IsNull([入库_金额],0) - ISNULL([销售_金额],0) - ISNULL([退货_金额],0)","库存_金额")
End With

Tables(tname).DefaultRowHeight = 35
DataTables(tname).DataCols("期初_数量").SetFormat("#,###.00")
DataTables(tname).DataCols("期初_金额").SetFormat("#,###.00")
DataTables(tname).DataCols("销售_数量").SetFormat("#,###.00")
DataTables(tname).DataCols("销售_金额").SetFormat("#,###.00")
DataTables(tname).DataCols("退货_数量").SetFormat("#,###.00")
DataTables(tname).DataCols("退货_金额").SetFormat("#,###.00")
DataTables(tname).DataCols("库存_数量").SetFormat("#,###.00")
DataTables(tname).DataCols("库存_金额").SetFormat("#,###.00")
Tables(tname).ResumeRedraw


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


加好友 发短信
等级:五尾狐 帖子:1014 积分:6757 威望:0 精华:0 注册:2014/2/12 20:14:00
  发帖心情 Post By:2014/8/14 20:48:00 [只看该作者]

.NET Framework 版本:2.0.50727.3655
Foxtable 版本:2014.5.12.1
错误所在事件:
详细错误信息:
至少一个参数没有被指定值。
有报错

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


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2014/8/14 20:50:00 [只看该作者]

Filter1 = "入库日期 <=  #" & lastD2 & "#"
Filter2 = "出库日期 <=  #" & lastD2 & "#"
Filter3 = "退货日期 <=  #" & lastD2 & "#"

 回到顶部
总数 15 1 2 下一页