Foxtable(狐表)用户栏目专家坐堂 → 入库的数量保存到库存表


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

主题:入库的数量保存到库存表

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


加好友 发短信
等级:小狐 帖子:346 积分:2645 威望:0 精华:0 注册:2018/11/11 15:52:00
入库的数量保存到库存表  发帖心情 Post By:2020/12/8 14:29:00 [只看该作者]

请问要把入库的数量保存到库存表是用什么方式   把数据直接复制去吗?相同规格的产品库存数量要相加 这个代码要怎么写?


 回到顶部
帅哥,在线噢!
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:107757 积分:548124 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/12/8 14:54:00 [只看该作者]

建议不要实时更改库存数量,连基本的代码都控制不好,更不用说使用代码控制好数量的准确性了。实时的库存计算可以说一个既非常简单也非常复杂的逻辑处理过程,我也说不明白。

建议需要的时候通过统计的方式计算库存,比如分组统计,分别统计入库和出库的数量,然后相减就是库存了。

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


加好友 发短信
等级:小狐 帖子:346 积分:2645 威望:0 精华:0 注册:2018/11/11 15:52:00
  发帖心情 Post By:2020/12/8 15:35:00 [只看该作者]

Dim bd1 As New GroupTableBuilder("统计表1",DataTables("入库明细表"))
Dim dt1 As fxDataSource
bd1.Groups.AddDef("仓库") '根据型号分组
bd1.Groups.AddDef("产地") '根据型号分组
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.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.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) '将退货统计数据组合到进货统计数据
'dt1.Show("统计表1") '显示统计结果

Tables("销售提单登记_Table2").DataSource = dt1 '将统计结果绑定到Table
With DataTables("销售提单登记_Table2").DataCols  '用表达式列计算库存数据
    .Add("库存_数量",Gettype(Integer), "IsNull([入库_数量],0) - ISNULL([出库_数量],0) - ISNULL([退货_数量],0)")
    .Add("库存_重量",Gettype(Double), "IsNull([入库_重量],0) - ISNULL([出库_重量],0) - ISNULL([退货_重量],0)")
End With

With Tables("销售提单登记_Table2")
    .Cols("库存_数量").GrandTotal = True
    .Cols("库存_重量").GrandTotal = True
   
    .GrandTotal = True
End With

 

 

可以按入库日期入库日期排下序吗?

[此贴子已经被作者于2020/12/8 15:35:24编辑过]

 回到顶部
帅哥,在线噢!
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:107757 积分:548124 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/12/8 16:04:00 [只看该作者]

统计表都没有日期,怎么排序?何况对于这种库存统计,这个日期排序有意义吗

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


加好友 发短信
等级:小狐 帖子:346 积分:2645 威望:0 精华:0 注册:2018/11/11 15:52:00
  发帖心情 Post By:2020/12/8 16:13:00 [只看该作者]

上面不是说库存用统计吗?开单时要按先进先出原则,先要查下库存在开单 统计时我加个日期进去看看

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


加好友 发短信
等级:小狐 帖子:346 积分:2645 威望:0 精华:0 注册:2018/11/11 15:52:00
  发帖心情 Post By:2020/12/8 16:18:00 [只看该作者]

Dim bd1 As New GroupTableBuilder("统计表1",DataTables("期初库存"))
Dim dt1 As fxDataSource

bd1.Groups.AddDef("仓库") '根据型号分组
bd1.Groups.AddDef("产地") '根据型号分组
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.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.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.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("销售提单登记_Table2").DataSource = dt1 '将统计结果绑定到Table
With DataTables("销售提单登记_Table2").DataCols  '用表达式列计算库存数据
    .Add("库存_数量",Gettype(Integer), "IsNull([期初_数量],0) + IsNull([入库_数量],0) - ISNULL([出库_数量],0) - ISNULL([退货_数量],0)")
    .Add("库存_重量",Gettype(Double), "IsNull([期初_重量],0) + IsNull([入库_数量],0) - ISNULL([出库_重量],0) - ISNULL([退货_重量],0)")
End With

With Tables("销售提单登记_Table2")
    .Cols("库存_数量").GrandTotal = True
    .Cols("库存_重量").GrandTotal = True  
    .GrandTotal = True
End With

 

 

要隐藏 期初数量和退货数量 可以吗?请问要怎样写代码?


 回到顶部
帅哥,在线噢!
有点蓝
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:107757 积分:548124 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/12/8 16:25:00 [只看该作者]


 回到顶部