以文本方式查看主题 - Foxtable(狐表) (http://foxtable.net/bbs/index.asp) -- 专家坐堂 (http://foxtable.net/bbs/list.asp?boardid=2) ---- 制造类库存 (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=53650) |
||||
-- 作者:石四 -- 发布时间:2014/7/12 15:22:00 -- 制造类库存 两个表:入库 耗用 入库表 入库数量 入库金额 耗用表 耗用数量 统计表结构 单价=(期初金额+入库金额)/(期初数量+入库数量) 期初_数量 期初_金额 入库_数量 入库_金额 耗用_数量 库存_数量 库存_金额
不会写“单价”的表达式,Fiter来Fiter去,晕菜了,帮帮忙。
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.Filter = Filter dt2 = bd2.BuildDataSource()
dt1.Combine("型号",dt2,"型号") \'将销售统计数据组合到进货统计数据 Tables("统计_Table1").DataSource = dt1 \'将统计结果绑定到Table
With DataTables("统计_Table1").DataCols \'用表达式列计算单价数据 .Add("单价") End With ?????????????????????
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 cmd As new SQLCommand cmd.CommandText = "select * from {进货} where " & Filter dt_jh = cmd.ExecuteReader cmd.CommandText = "select * from {销售} where " & Filter dt_xs = cmd.ExecuteReader
For Each r As Row In Tables("统计_Table1").Rows Filter = "型号 = \'" & r("型号") & "\'" r("期初_数量") = dt_jh.Compute("sum(进货_数量)", filter) - dt_xs.Compute("sum(销售_数量)", filter) r("期初_金额") = dt_jh.Compute("sum(进货_金额)", filter) Next
With DataTables("统计_Table1").DataCols \'用表达式列计算库存数据 .Add("库存_数量",Gettype(Double), "IsNull([期初_数量],0) + IsNull([进货_数量],0) - ISNULL([销售_数量],0) .Add("库存_金额",Gettype(Double), "[期初_金额] * [单价]","库存_金额") End With
Tables("统计_Table1").SetColVisibleWidth("型号|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") Tables("统计_Table1").ResumeRedraw
[此贴子已经被作者于2014-7-12 15:23:32编辑过]
|
||||
-- 作者:Bin -- 发布时间:2014/7/12 15:49:00 -- 你希望怎么计算? |
||||
-- 作者:石四 -- 发布时间:2014/7/12 15:55:00 -- 添加一个“单价”列,单价=(期初金额+入库金额)/(期初数量+入库数量) 库存金额 = 库存数量*单价
[此贴子已经被作者于2014-7-12 15:55:24编辑过]
|
||||
-- 作者:石四 -- 发布时间:2014/7/13 9:44:00 -- 之前月进货数据用dt_jh 引用,当前月统计数据在dt1(统计表1),那么当前月的数量和金额应该怎样引用? |
||||
-- 作者:有点甜 -- 发布时间:2014/7/13 10:01:00 -- 代码
\'If DataTables.Contains("进货") = False Then With e.Form.Controls("日期") Dim bd1 As New SQLGroupTableBuilder("统计表1","进货") Dim bd2 As New SQLGroupTableBuilder("统计表2","销售") Dim bd3 As New SQLGroupTableBuilder("统计表3","退货") dt1.Combine("型号",dt2,"型号") \'将销售统计数据组合到进货统计数据 With DataTables("统计_Table1").DataCols \'用表达式列计算库存数据 Filter = "日期 <= #" & lastD2 & "#" For Each r As Row In Tables("统计_Table1").Rows 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 |
||||
-- 作者:石四 -- 发布时间:2014/7/13 10:09:00 -- 慢慢消化先,类似的以后会常用。 |
||||
-- 作者:石四 -- 发布时间:2014/7/15 21:19:00 -- With e.Form.Controls("日期") Dim jb As new SQLJoinTableBuilder("查询表2","计划排产") Dim bd1 As New GroupTableBuilder("统计表5", jb.BuildSQL,"服务器") Dim bd2 As New SQLGroupTableBuilder("统计表6","材料入库") With DataTables("材料月报2_Table1").DataCols \'用表达式列计算库存数据 For Each r As Row In Tables("材料月报2_Table1").Rows |
||||
-- 作者:有点甜 -- 发布时间:2014/7/15 21:21:00 -- 什么 意思? |
||||
-- 作者:石四 -- 发布时间:2014/7/15 21:38:00 -- 另外开了贴 |