Foxtable(狐表)用户栏目专家坐堂 → [求助]程序运行出错(已解决)


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

主题:[求助]程序运行出错(已解决)

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


加好友 发短信
等级:七尾狐 帖子:1528 积分:10618 威望:0 精华:0 注册:2008/9/24 11:16:00
[求助]程序运行出错(已解决)  发帖心情 Post By:2012/3/15 14:20:00 [只看该作者]

原来运行正常,软件升级后出错,请各位老师指教,谢谢!

 

 


图片点击可在新窗口打开查看此主题相关图片如下:f.png
图片点击可在新窗口打开查看

 

DataColChanged事件代码如下:

 

'跨表引用(表关联)
Select Case  e.DataCol.Name
    Case = "设备编号"
        Dim nms() As String = {"设备名称","名称","折旧基数","折旧年限"}
        If e.NewValue Is Nothing Then
            For Each nm As String In nms
                e.DataRow(nm) = Nothing
            Next
        Else
            Dim dr As DataRow = DataTables("设备目录").Find("[设备编号] = '" & e.NewValue & "'")
            If dr IsNot Nothing
                For Each nm As String In nms
                    e.DataRow(nm) = dr(nm)
                Next
            End If
        End If
End Select
'使用单位(跨表引用)
Select Case  e.DataCol.Name
    Case "去向"
        If e.DataRow.IsNull("去向") And  e.DataRow.IsNull("使用单位") Then
            e.DataRow("归还日期")=Nothing
        Else
            Dim dr As DataRow = DataTables("设备目录").Find("[设备编号] = '" & e.DataRow("设备编号") & "'")
            If e.DataRow.IsNull("去向") Then
                Dim mydate As Date = Date.Today()
                Dim y As Integer = mydate.Year
                Dim m As Integer = mydate.Month
                Dim Days As Integer = Date.DaysInMonth(y,m)
                Dim d As Date = New Date(y,m,Days)
                e.DataRow("归还日期") = d
                If dr IsNot Nothing Then
                    dr("使用单位") = e.DataRow("使用单位")
                Else
                    dr("使用单位") = e.DataRow("产权单位")
                End If
            End If
        End If
End Select
'日历天数(工作日废除)
Select Case  e.DataCol.Name
    Case "借用日期","归还日期"
        If e.DataRow.IsNull("借用日期") And  e.DataRow.IsNull("归还日期") Then
            e.DataRow("日历天数")=Nothing
        Else
            Dim mydate As Date = Date.Today()
            Dim y As Integer = mydate.Year
            Dim m As Integer = mydate.Month
            Dim Days As Integer = Date.DaysInMonth(y,m)
            Dim d As Date = New Date(y,m,Days)
            Dim d1 As Date = e.DataRow("借用日期")
            Dim d2 As Date = e.DataRow("归还日期")
            If d1 > d2 OrElse d1 > d
                e.DataRow("日历天数") = 0
            Else
                Dim cnt As Integer
                If d2 > d
                    cnt = (d-d1).TotalDays
                Else
                    cnt = (d2-d1).TotalDays
                End If
                e.DataRow("日历天数") = cnt
            End If
        End If
End Select
'日租金
Select Case  e.DataCol.Name
    Case "折旧基数","折旧年限"
        Dim dr As DataRow = e.DataRow
        If dr.IsNull("折旧基数") OrElse dr.IsNull("折旧年限") Then
            dr("日租金") = Nothing
        Else
            dr("日租金") = dr("折旧基数") / (dr("折旧年限")*365)*1.5
        End If
End Select
'租金累计
Select Case  e.DataCol.Name
    Case "日租金","日历天数"
        Dim dr As DataRow = e.DataRow
        If dr.IsNull("日租金") OrElse dr.IsNull("日历天数") Then
            dr("租金累计") = Nothing
        Else
            dr("租金累计") =IIF(dr("使用单位")= "仓库",0,IIF(dr("产权单位") = dr("使用单位"),0,dr("日租金") * dr("日历天数")))
        End If
End Select
'产权单位(跨表引用)
Select Case  e.DataCol.Name
    Case "设备编号","借用日期","归还日期"
        Dim dr As DataRow = e.DataRow
        Dim pr As DataRow
        If dr.IsNull("设备编号") OrElse dr.IsNull("借用日期") OrElse dr.IsNull("归还日期") Then
            dr("产权单位") = Nothing
        Else
            Dim filter As String
            filter = "设备编号 = '" & dr("设备编号") & "' And 启用日期 <= '" & dr("借用日期") & "' And 停用日期 >= '" & dr("归还日期") & "'"
            pr = DataTables("设备折旧").Find(filter)
            If pr IsNot Nothing Then
                dr("产权单位") = pr("产权单位")
            End If
        End If
End Select
'当月租金
Select Case  e.DataCol.Name
    Case "借用日期","归还日期"
        If e.DataRow.IsNull("借用日期") And  e.DataRow.IsNull("归还日期") Then
            e.DataRow("当月租金")=Nothing
        Else
            Dim mydate As Date = Date.Today()
            Dim y As Integer = mydate.Year
            Dim m As Integer = mydate.Month
            Dim Days As Integer = Date.DaysInMonth(y,m)
            Dim c As Date =  (New Date(y,m,1)).adddays(-1)
            Dim d As Date = New Date(y,m,Days)
            Dim a As Date = e.DataRow("借用日期")
            Dim b As Date = e.DataRow("归还日期")
            Dim cnt As Integer   '日历天数
            If b<c OrElse a>d
                cnt = 0
            Else If a<c AndAlso b>=d
                cnt = (d-c).TotalDays
            Else If a>c AndAlso b>d
                cnt = (d-a).TotalDays
            Else If a<c AndAlso b<d
                cnt = (b-c).TotalDays
            Else cnt = (b-a).TotalDays
            End If
            Dim dr As DataRow = e.DataRow
            e.DataRow("当月租金") = IIF(dr("使用单位")= "仓库",0,IIF(dr("产权单位") = dr("使用单位"),0,dr("日租金") * cnt))
        End If
End Select

[此贴子已经被作者于2012-3-16 8:19:00编辑过]

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


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


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


加好友 发短信
等级:七尾狐 帖子:1528 积分:10618 威望:0 精华:0 注册:2008/9/24 11:16:00
  发帖心情 Post By:2012/3/16 8:18:00 [只看该作者]

谢谢狐爸老师的指教,问题找到了,在设备编号有一行为“.”,是填报人员的手误,修改后,问题解决。
[此贴子已经被作者于2012-3-16 8:20:05编辑过]

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


加好友 发短信
等级:管理员 帖子:47497 积分:251397 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2012/3/16 8:42:00 [只看该作者]

你还是得修改代码,因为用户输入不可能100%正确
[此贴子已经被作者于2012-3-16 8:41:57编辑过]

 回到顶部