Foxtable(狐表)用户栏目专家坐堂 → [求助]增加行


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

主题:[求助]增加行

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


加好友 发短信
等级:三尾狐 帖子:636 积分:4062 威望:0 精华:0 注册:2016/10/19 16:45:00
[求助]增加行  发帖心情 Post By:2016/10/26 11:12:00 [只看该作者]

老师好,下面代码报错,增加行时入库单编号还没有生成要日期单元格输入时间后才能生成入库单编号。

Select Case e.DataCol.Name 
    Case "入库单编号"
        If e.DataRow.IsNull("入库单编号") = False Then '如果已经输入订单编号
            If e.DataRow.GetChildRows("入库明细").Count = 0 Then '而且无订单明细
                Dim dr As DataRow = DataTables("入库明细").AddNew()
                dr("入库单编号") = e.DataRow("入库单编号")
            End If
        End If
End Select

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


加好友 发短信
等级:超级版主 帖子:107783 积分:548260 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2016/10/26 11:57:00 [只看该作者]

报什么错误?2个表有没有做关联?

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


加好友 发短信
等级:三尾狐 帖子:636 积分:4062 威望:0 精华:0 注册:2016/10/19 16:45:00
  发帖心情 Post By:2016/10/26 12:45:00 [只看该作者]


老师,关联了。不是点击确定按钮是对话框关闭按钮。



图片点击可在新窗口打开查看此主题相关图片如下:图像 3.png
图片点击可在新窗口打开查看
[此贴子已经被作者于2016/10/26 12:47:27编辑过]

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


加好友 发短信
等级:超级版主 帖子:107783 积分:548260 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2016/10/26 14:14:00 [只看该作者]

错误提示是入库明细的datacolchanged事件有问题,不是入库单的这个事件

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


加好友 发短信
等级:三尾狐 帖子:636 积分:4062 威望:0 精华:0 注册:2016/10/19 16:45:00
  发帖心情 Post By:2016/10/26 18:41:00 [只看该作者]

老师,应该摆在那个事件里。

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


加好友 发短信
等级:超级版主 帖子:107783 积分:548260 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2016/10/26 20:19:00 [只看该作者]

不是摆在那个事件的问题。


是入库明细的datacolchanged事件有问题,把入库明细的datacolchanged事件代码贴上来看看

建议先花时间看看开发指南的视频:http://pan.baidu.com/s/1kV8pUwn#list/path=%2F

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


加好友 发短信
等级:三尾狐 帖子:636 积分:4062 威望:0 精华:0 注册:2016/10/19 16:45:00
  发帖心情 Post By:2016/10/26 20:53:00 [只看该作者]



 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:新建 文本文档.txt


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


加好友 发短信
等级:超级版主 帖子:107783 积分:548260 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2016/10/26 21:13:00 [只看该作者]


按照下面的方式每一段代码后面加上MessageBox.Show,看运行到哪一个MessageBox之后出错了

然后缩小范围在代码段里面加上MessageBox,看是那一句代码有问题

'自动输入入库单编号明细列的值
Select Case e.DataCol.Name
    Case "入库单编号"
        If e.DataRow.IsNull("入库单编号") Then
            e.DataRow("入库单编号明细") = Nothing
        Else
            Dim bh As  String = e.DataRow("入库单编号")
            Dim max  As  String
            Dim idx  As  Integer
            max = e.DataTable.Compute("Max(入库单编号明细)","入库单编号 = '" & bh  & "' And [_Identify] <> " & e.DataRow("_Identify")) '取得该类别的最大入库单编号
            If max > ""  Then  '如果存在最大入库单编号
                Dim l As Integer = bh.Length
                idx = CInt(max.Substring(l,3)) + 1  '获得最大入库单编号的后两位顺序号,并加1
            Else
                idx = 1  '否则顺序号等于1
            End  If
            e.DataRow("入库单编号明细") = bh & Format(idx,"000")
            
        End If
End Select
MessageBox.Show(1)

'===============================提取字符=============================================
Dim s As String = e.DataRow("入库单编号明细")
e.DataRow("批次号") = s.SubString(s.Length-6,3) & s.SubString(s.Length-2,2)

MessageBox.Show(2)
'==================================================================================================
Dim ck As DataRow = e.DataRow
Select Case e.DataCol.Name
    Case "入库_数量","入库_单价","入库_税率"
        ck("入库_金额") = ck("入库_单价") * ck("入库_数量") / ck("入库_税率")
    Case "入库_单价","入库_数量","入库_金额"
        ck("入库_税金") = ck("入库_单价") * ck("入库_数量") - ck("入库_金额")
    Case "入库_金额","入库_税金"
        ck("入库_价税合计") = ck("入库_金额") + ck("入库_税金")
    Case "运输_数量","运输_单价"
        ck("运输_金额") = ck("运输_数量") * ck("运输_单价")
    Case "入库_价税合计","运输_金额"
        ck("合计金额") = ck("入库_价税合计") + ck("运输_金额")
End Select
MessageBox.Show(3)
'-----------------------------------------------------------计算库存------------------------------------------
Select Case e.DataCol.Name
    Case "入库单编号明细","入库批次号","入库_数量"
        Dim filter As String = "入库批次号 = '" & e.DataRow("入库单编号明细") & "' and 批次号 = '" & e.DataRow("批次号")  & "'"
        e.DataRow("库存") = e.DataRow("入库_数量") - DataTables("出库明细").Compute("sum(出库_数量)", filter)
End Select
MessageBox.Show(4)

.......后面的其它段自己补上MessageBox.Show

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


加好友 发短信
等级:三尾狐 帖子:636 积分:4062 威望:0 精华:0 注册:2016/10/19 16:45:00
  发帖心情 Post By:2016/10/26 21:36:00 [只看该作者]

老师,那个对话框循环运作关不掉。没有报错.

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


加好友 发短信
等级:三尾狐 帖子:636 积分:4062 威望:0 精华:0 注册:2016/10/19 16:45:00
  发帖心情 Post By:2016/10/26 21:41:00 [只看该作者]

老师,好像是这一组代码出错

Select Case e.DataCol.Name
    Case "入库单编号"
        If e.DataRow.IsNull("入库单编号") Then
            e.DataRow("入库单编号明细") = Nothing
        Else
            Dim bh As  String = e.DataRow("入库单编号")
            Dim max  As  String
            Dim idx  As  Integer
            max = e.DataTable.Compute("Max(入库单编号明细)","入库单编号 = '" & bh  & "' And [_Identify] <> " & e.DataRow("_Identify")) '取得该类别的最大入库单编号
            If max > ""  Then  '如果存在最大入库单编号
                Dim l As Integer = bh.Length
                idx = CInt(max.Substring(l,3)) + 1  '获得最大入库单编号的后两位顺序号,并加1
            Else
                idx = 1  '否则顺序号等于1
            End  If
            e.DataRow("入库单编号明细") = bh & Format(idx,"000")
            
        End If
End Select

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