Foxtable(狐表)用户栏目专家坐堂 → 流水帐


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

主题:流水帐

美女呀,离线,留言给我吧!
cjl333333333
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:童狐 帖子:200 积分:1706 威望:0 精华:0 注册:2015/2/3 17:04:00
流水帐  发帖心情 Post By:2021/7/21 16:35:00 [只看该作者]

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

老师这个项目库存数量老是不对,然后我是外部数据表的,每次加载最后一天的数据。

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


加好友 发短信
等级:超级版主 帖子:106464 积分:541467 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2021/7/21 16:38:00 [只看该作者]

重置列后检查数据没有问题。模仿原项目,做个功能一样有问题的测试项目发过来测试

 回到顶部
美女呀,离线,留言给我吧!
cjl333333333
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:童狐 帖子:200 积分:1706 威望:0 精华:0 注册:2015/2/3 17:04:00
  发帖心情 Post By:2021/7/21 17:21:00 [只看该作者]

老师你再帮我看看,我就是下面这个代码,其它没问题就是全部数据加载出来的他都计算对的,就是没加载就会计成库存数量0
Select Case e.DataCol.Name
    Case "编号","入库数量","出库数量","入库件数","出库件数"
        
        Dim dr As DataRow
        Dim mr As DataRow = e.DataRow
        Dim drs As List(of DataRow)
        Dim jk As Integer
        Dim ck As Integer
        Dim jk1 As Integer
        Dim ck1 As Integer
        
        dr = e.DataTable.SQLFind("[_SortKey] < " & mr("_SortKey") & " And [编号] = '" & mr("编号") & "'", "[_SortKey] Desc")
        
        If dr Is Nothing Then '如果是第一行,计算结存
            
            jk =  DataTables("库存表").SQLCompute("Sum(入库数量)","[_SortKey] < " & mr("_SortKey") & " And 编号 = '" & mr("编号") & "'")
            jk1 =  DataTables("库存表").SQLCompute("Sum(入库件数)","[_SortKey] < " & mr("_SortKey") & " And 编号 = '" & mr("编号") & "'")
            ck =  DataTables("库存表").SQLCompute("Sum(出库数量)","[_SortKey] < " & mr("_SortKey") & " And 编号 = '" & mr("编号") & "'")
            ck1 =  DataTables("库存表").SQLCompute("Sum(出库件数)","[_SortKey] < " & mr("_SortKey") & " And 编号 = '" & mr("编号") & "'")
            
            mr("库存数量") = e.DataRow("入库数量") - e.DataRow("出库数量") + jk - ck
            mr("库存件数") = e.DataRow("入库件数") - e.DataRow("出库件数") + jk1 - ck1
            
            dr = mr
        End If
        drs = e.DataTable.Select("[_SortKey] >= " & dr("_SortKey") & " And [编号] = '" & dr("编号") & "'", "[_SortKey]")
        For i As Integer = 1 To drs.Count - 1
            
            drs(i)("库存数量") = drs(i-1)("库存数量") + drs(i)("入库数量") - drs(i)("出库数量")
            drs(i)("库存件数") = drs(i-1)("库存件数") + drs(i)("入库件数") - drs(i)("出库件数")
            
        Next
        If e.DataCol.Name = "编号" AndAlso e.OldValue IsNot Nothing AndAlso e.OldValue <> e.NewValue Then '如果修改的是产品列
            dr = e.DataTable.SQLFind("[_SortKey] < " & mr("_SortKey") & " And [编号] = '" & e.OldValue & "'", "[_SortKey] Desc") '找出旧产品的上一行
            If dr Is Nothing Then '如果不存在上一行,那么本行就是旧产品的第一行,由于已经被修改为新产品,需要找出旧产品现在的第一行
                dr = e.DataTable.SQLFind("[编号] = '" & e.OldValue & "'", "[_SortKey]") '找出旧产品现在的第一行
                If dr IsNot Nothing Then '如果找到,计算库存
                    
                    jk =  DataTables("库存表").SQLCompute("Sum(入库数量)","[_SortKey] < " & mr("_SortKey") & " And 编号 = '" & e.OldValue & "'")
                    jk1 =  DataTables("库存表").SQLCompute("Sum(入库件数)","[_SortKey] < " & mr("_SortKey") & " And 编号 = '" & e.OldValue & "'")
                    ck =  DataTables("库存表").SQLCompute("Sum(出库数量)","[_SortKey] < " & mr("_SortKey") & " And 编号 = '" & e.OldValue & "'")
                    ck1 =  DataTables("库存表").SQLCompute("Sum(出库件数)","[_SortKey] < " & mr("_SortKey") & " And 编号 = '" & e.OldValue & "'")
                    dr("库存数量") = dr("入库数量") - dr("出库数量") + jk - ck
                    dr("库存件数") = dr("入库件数") - dr("出库件数") + jk1 - ck1
                    
                End If
            End If
            If dr IsNot Nothing Then
                
                drs = e.DataTable.Select("[_SortKey] >= " & dr("_SortKey") & " And [编号] = '" & dr("编号") & "'", "[_SortKey]")
                For i As Integer = 1 To drs.Count - 1
                    
                    drs(i)("库存数量") = drs(i-1)("库存数量") + drs(i)("入库数量") - drs(i)("出库数量")
                    drs(i)("库存件数") = drs(i-1)("库存件数") + drs(i)("入库件数") - drs(i)("出库件数")
                    
                Next
            End If
        End If
End Select


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


加好友 发短信
等级:超级版主 帖子:106464 积分:541467 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2021/7/21 17:27:00 [只看该作者]

SQLFind改为Find

 回到顶部