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


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

主题:流水账问题

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


加好友 发短信
等级:七尾狐 帖子:1551 积分:10061 威望:0 精华:0 注册:2014/12/18 16:12:00
流水账问题  发帖心情 Post By:2017/4/2 9:48:00 [只看该作者]

我有一个出入库流水账,现在的代码是这样的:

 

Datacolchanged

 

Select Case e.DataCol.Name

    Case "物料编号","入库数量","出库数量"

        Dim dr As DataRow

        Dim mr As DataRow = e.DataRow

        Dim drs As List(of DataRow)

        dr = e.DataTable.Find("[_SortKey] < " & mr("_SortKey") & " And [物料编号] = '" & mr("物料编号") & "'", "[_SortKey] Desc")

        If dr Is Nothing Then

            mr("余数") = mr("入库数量") + mr("出库数量")

            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)("出库数量")

        Next

        If e.DataCol.Name = "物料编号" AndAlso e.OldValue IsNot Nothing AndAlso e.OldValue <> e.NewValue Then

            dr = e.DataTable.Find("[_SortKey] < " & mr("_SortKey") & " And [物料编号] = '" & e.OldValue & "'", "[_SortKey] Desc")

            If dr Is Nothing Then

                dr = e.DataTable.Find("[物料编号] = '" & e.OldValue & "'", "[_SortKey]")

                If dr IsNot Nothing Then

                    dr("余数") = dr("入库数量") + dr("出库数量")

                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)("出库数量")

                Next

            End If

        End If

End Select

 

Aftermoverow


Dim Key As Decimal

Dim Index As Integer

Dim Filter As String

Dim r As Row

Index = Math.Min(e.OldIndex, e.NewIndex)

Key = e.Table.Rows(Index)("_SortKey")

r = e.Table.Rows(e.NewIndex)

Filter = "[_SortKey] >= " & Key & " And [物料编号] = '" & r("物料编号") & "'"

e.Table.DataTable.DataCols("入库数量").RaiseDataColChanged(Filter)

 

datarowdeleting


e.DataRow("入库数量") = 0

e.DataRow("出库数量") = 0

 

我的问题是,我在afteropenproject加了排序的代码,所以,待我完全进入系统之后,余数这栏的数据就不对了,也就是说,再也不像流水账了。我希望在对数据进行重新排序之后,流水账的余数也能自动发生变化,应该在哪里加些什么代码呢?

谢谢。


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


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

 把_sortkey改成你的排序列。

 

 看完 http://www.foxtable.com/bbs/dispbbs.asp?BoardID=2&ID=96147&skin=0

 


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


加好友 发短信
等级:七尾狐 帖子:1551 积分:10061 威望:0 精华:0 注册:2014/12/18 16:12:00
  发帖心情 Post By:2017/4/2 13:17:00 [只看该作者]

可是我afteropenproject的排序代码是这样的:Tables("出入库").Sort = "出入库日期,出入库单号,物料编号"。怎么处理好?

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


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

 把_sortkey改成出入库日期。

 

 多条件的,有多少个条件,那么合成的字符,就连接多少个字符。

 

 不会做,上传实例。


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


加好友 发短信
等级:七尾狐 帖子:1551 积分:10061 威望:0 精华:0 注册:2014/12/18 16:12:00
  发帖心情 Post By:2017/4/2 15:51:00 [只看该作者]

我出入库日期是表达式列,如何将出入库日期改为_sortkey?

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


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

认认真真看2楼,把代码 _Sortkey 改成你的日期列。

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


加好友 发短信
等级:七尾狐 帖子:1551 积分:10061 威望:0 精华:0 注册:2014/12/18 16:12:00
  发帖心情 Post By:2017/8/9 18:17:00 [只看该作者]

我在afteropenproject 里面的排序是这样的:Tables("出入库").Sort = "出入库日期,出入原因 desc,出入库单号",那么如何修改我的datacolumnchanged 和 aftermoverow 代码?谢谢。

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


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

 为什么要修改datacolchanged事件?

 

 既然你排序了,那么,aftermoveRow就不会有效了,不需要写。


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


加好友 发短信
等级:七尾狐 帖子:1551 积分:10061 威望:0 精华:0 注册:2014/12/18 16:12:00
  发帖心情 Post By:2017/8/10 11:37:00 [只看该作者]

我把aftermoveRow删除了,也是达不到要求的效果。

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


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

以下是引用edisontsui在2017/8/10 11:37:00的发言:
我把aftermoveRow删除了,也是达不到要求的效果。

 

上传实例说明你的问题。


 回到顶部
总数 32 1 2 3 4 下一页