以文本方式查看主题 - Foxtable(狐表) (http://foxtable.com/bbs/index.asp) -- 专家坐堂 (http://foxtable.com/bbs/list.asp?boardid=2) ---- 切换页面卡机 (http://foxtable.com/bbs/dispbbs.asp?boardid=2&id=157171) |
-- 作者:huaqing8828 -- 发布时间:2020/10/6 10:43:00 -- 切换页面卡机 请老师看一下这段代码有问题吗?这段代码我删掉后切换这个页面就不卡机。否则就卡机。请老师指教 Select Case e.DataCol.Name Case "发货批号","现送数量","送货日期" Dim drs As List(of DataRow) Dim Filter As String Filter = "[送货日期] >= #" & e.DataRow("送货日期") & "# And [发货批号] = \'" & e.DataRow("发货批号") & "\'" drs = e.DataTable.Select(Filter) For Each dr As DataRow In drs Filter = "iif([送货日期] < #" & dr("送货日期") & "#, [送货日期] < #" & dr("送货日期") & "# And [发货批号] = \'" & dr("发货批号") & "\', [送货日期] = #" & dr("送货日期") & "# and _sortkey <= " & dr("_sortkey") & " And [发货批号] = \'" & dr("发货批号") & "\')" Dim Val1 As Double = e.DataTable.Compute("Sum(现送数量)",Filter) dr("已送数量") = Val1 - dr("现送数量") Next If e.DataCol.Name = "发货批号" AndAlso e.OldValue IsNot Nothing AndAlso e.OldValue <> e.NewValue Then Filter = "[送货日期] > #" & e.DataRow("送货日期") & "# And [发货批号] = \'" & e.OldValue & "\'" drs = e.DataTable.Select(Filter) For Each dr As DataRow In drs Filter = "iif([送货日期] < #" & dr("送货日期") & "#, [送货日期] < #" & dr("送货日期") & "# And [发货批号] = \'" & dr("发货批号") & "\', [送货日期] = #" & dr("送货日期") & "# and _sortkey <= " & dr("_sortkey") & " And [发货批号] = \'" & dr("发货批号") & "\')" Dim Val1 As Double = e.DataTable.Compute("Sum(现送数量)",Filter) dr("已送数量") = Val1 - dr("现送数量") Next End If End Select |
-- 作者:有点蓝 -- 发布时间:2020/10/6 10:54:00 -- 如果是在datacolchanged事件,切换表不可能会执行的。应该是有其他代码影响了,比如重置列的代码,或者在切换表的时候改变了"发货批号","现送数量","送货日期"这几列的数据 |
-- 作者:huaqing8828 -- 发布时间:2020/10/6 13:07:00 -- 谢谢老师,我再检查一下 |
-- 作者:huaqing8828 -- 发布时间:2020/10/6 14:00:00 -- 老师我是在datacolchanged事件里写上面的代码的,检查过了问题就出现在"发货批号","现送数量","送货日期"这三列,这三列的任意一列我按一下重置列都卡机。老师应该怎么解决啊 |
-- 作者:有点蓝 -- 发布时间:2020/10/6 14:22:00 -- 如果数据多,没有办法。可以考虑从业务逻辑上优化,具体上传实例看看有没有变通的方法 |
-- 作者:huaqing8828 -- 发布时间:2020/10/6 15:15:00 -- 老师我现在只保存三天的数据,就可以切换了。实际上我只需要保存三天的数据,那么老师三天以前的数据可以做到自动删除吗 |
-- 作者:有点蓝 -- 发布时间:2020/10/6 15:21:00 -- 可以在afteropenproject事件打开项目时删除:http://www.foxtable.com/webhelp/topics/0394.htm |
-- 作者:huaqing8828 -- 发布时间:2020/10/6 16:41:00 -- 可以了,谢谢老师 |