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


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

主题:求助

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


加好友 发短信
等级:一尾狐 帖子:412 积分:2665 威望:0 精华:0 注册:2015/10/2 23:48:00
求助  发帖心情 Post By:2017/3/3 15:14:00 [只看该作者]

现有一个出库窗口,在窗口中有一个控件是出库数量,在TextChanged 中想实现如果出库数量小于该商品号所在的其中一个库位中的数量,直接遍历赋值,再扣减库存,假如出库数量大于任何一个其中的库位,则按入库日期秉承先进先出原则,若干个库位中的库存相加满足出库量则止,并把这些库位列出到窗口库位控件中,以便接下来打印出库单。我写了些代码,接下来的要怎样完成,望指导。
 代码如下:
Dim pbx As WinForm.PictureBox
pbx = e.form.Controls("提示")
Dim sl As Double = val(e.Sender.text)
Dim kykc As Double = val(e.form.Controls("可用库存").text)
Dim dj As Double = val(e.form.Controls("单价").value)
If sl = Nothing Then
    e.Form.Controls("出库数量").text = "0 " 
    pbx.Image = GetImage("Images\exclamation.gif")
    e.Form.Controls("提示信息").text = "请输入出库数量,不能为空!"
    e.Form.Controls("提示信息").ForeColor = Color.Red
    e.Form.Controls("增加").Enabled = False
    Return
End If
If sl = 0 Then
    e.Form.Controls("出库数量").text = "0 " 
    pbx.Image = GetImage("Images\exclamation.gif")
    e.Form.Controls("提示信息").text = "出库数量必须大于 0"
    e.Form.Controls("提示信息").ForeColor = Color.Red
    e.Form.Controls("增加").Enabled = False
    Return
ElseIf sl > kykc Then
    e.Form.Controls("出库数量").text = "0 " 
    pbx.Image = GetImage("Images\exclamation.gif")
    e.Form.Controls("提示信息").text = "库存可用数量不足本次出库!"
    e.Form.Controls("提示信息").ForeColor = Color.Red
    e.Form.Controls("增加").Enabled = False
    Return
else
e.Form.Controls("出库数量").text = sl 

Dim dr As DataRow = DataTables("商品库存明细").Find("Item = '" & e.Form.Controls("商品编号").text & "'")

 

If dr IsNot Nothing Then

Dim wz As Integer = Tables("商品库存明细").FindRow(dr)

        If wz >= 0 Then

            Tables("商品库存明细").Position = wz

        End If

If dr("可用库存") sl Then

        

        e.Form.Controls("单价").text = dr("单价") & " 元"

        e.Form.Controls("总价").text = Format(dr(“单价”) * sl,"n")  & " 元

        If dr("生产日期") = Nothing Then

            e.Form.Controls("生产日期").text = "未知"

        Else

            e.Form.Controls("生产日期").text = dr("生产日期")

        End If

        If dr("有效期至") = Nothing Then

            e.Form.Controls("有效期至").text = "未知"

        Else

           e.Form.Controls("有效期至").text = dr("有效期至")

        End If

        e.Form.Controls("规格").text = dr("Pack Size")

        e.Form.Controls("商品状态").text = dr("商品状态")

        e.Form.Controls("库位").text = dr("库位")

       

    End If

End If

End if

If dj = Nothing Then
    pbx.Image = GetImage("Images\exclamation.gif")
    e.Form.Controls("提示信息").text = "商品单价为空,请尽量完善!"
    e.Form.Controls("提示信息").ForeColor = Color.Red
    e.Form.Controls("增加").Enabled = True
    Return
End If
If dj = 0 Then
    pbx.Image = GetImage("Images\exclamation.gif")
    e.Form.Controls("提示信息").text = "商品单价为 0 ,请尽量完善!"
    e.Form.Controls("提示信息").ForeColor = Color.Red
    e.Form.Controls("增加").Enabled = True
    Return
End If
e.Form.Controls("增加").Enabled = True
pbx.Image = GetImage("Images\payment_card.png")
e.Form.Controls("提示信息").text = "金额小计: " & Format(dj * sl,"n")  & " 元"
e.Form.Controls("提示信息").ForeColor = Color.black

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


加好友 发短信
等级:管理员 帖子:47448 积分:251048 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2017/3/3 15:19:00 [只看该作者]

涉及到具体业务逻辑,别人很难帮得上忙,因为理解不了你的设计逻辑,最好化为具体的技术问题。

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


加好友 发短信
等级:一尾狐 帖子:412 积分:2665 威望:0 精华:0 注册:2015/10/2 23:48:00
  发帖心情 Post By:2017/3/3 15:32:00 [只看该作者]

我得好好理一理,是这样,比如出库数量是80个商品编号为A10001的商品,在库存明细表中,A10001有3个库位存储,库位1:A-1  库位2:B-1 库位3:C-1 对应的有库存:20, 70, 75 ,对应的入库日期:2016-1-10     2016-12-10    2016-05-05 
逻辑是 假如是其中一个库位直接满足出库量,直接在该库位出,如果不满足,如上:三个库位都不满足出库量,则需要按入库日期的顺序把库存相加直到满足出库量,上面的最终的出库单上库位提示是在 A-1 和 C-1 提货出库 代码需要怎样实现


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


加好友 发短信
等级:超级版主 帖子:106199 积分:540118 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2017/3/3 15:58:00 [只看该作者]

上传实例测试

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


加好友 发短信
等级:超级版主 帖子:13837 积分:69650 威望:0 精华:0 注册:2016/11/1 14:42:00
  发帖心情 Post By:2017/3/3 16:43:00 [只看该作者]

 一个库是否满足的,直接查询有没有大于的即可。

 

 先进先出,参考这个例子 http://www.foxtable.com/bbs/dispbbs.asp?BoardID=2&ID=82143&skin=0

 


 回到顶部