Foxtable(狐表)用户栏目专家坐堂 → 编号生成的问题


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

主题:编号生成的问题

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


加好友 发短信
等级:小狐 帖子:319 积分:2494 威望:0 精华:0 注册:2012/5/19 22:40:00
编号生成的问题  发帖心情 Post By:2014/10/16 16:18:00 [只看该作者]

甜版,又来请教了
我参照帮助做了一个自动生成编号功能,但是总是无法实现自动叠加的功能,请帮忙看看吧。谢谢
代码如下,不知问题在哪里?(去掉& "-"就可以,一加上就不行,每行总是CI201409001-001不变

表事件

 

监造周报_DataColChanged

 

Select e.DataCol.Name

    Case "监造流水号"

        If e.DataRow.IsNull("监造流水号") Then

            e.DataRow("周报编号") = Nothing

        Else

            Dim lb As String = e.DataRow("监造流水号") & "-" '生成编号的前缀

            If e.DataRow("周报编号").StartsWith(lb) = False '如果单据编号前缀不符

                Dim max As String

                Dim idx As Integer

                max = e.DataTable.Compute("Max(周报编号)","监造流水号 = '" & lb & "' And [_Identify] <> " & e.DataRow("_Identify")) '取得该类别的最大编号

                If max > "" Then '如果存在最大编号

                    idx = CInt(max.Substring(12,3)) + 1 '获得最大编号的后三位顺序号,并加1

                Else

                    idx = 1 '否则顺序号等于1

                End If

                e.DataRow("周报编号") = lb & Format(idx,"000")

            End If

        End If

End Select

希望的效果:

监造流水号

周报编号

CI201409001

CI201409001-001

CI201409001

CI201409001-002


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


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

红色部分,你自己想想为什么:

 

Select e.DataCol.Name

    Case "监造流水号"

        If e.DataRow.IsNull("监造流水号") Then

            e.DataRow("周报编号") = Nothing

        Else

            Dim lb As String = e.DataRow("监造流水号") & "-" '生成编号的前缀

            If e.DataRow("周报编号").StartsWith(lb) = False '如果单据编号前缀不符

                Dim max As String

                Dim idx As Integer

                max = e.DataTable.Compute("Max(周报编号)","监造流水号 = '" & e.DataRow("监造流水号") & "' And [_Identify] <> " & e.DataRow("_Identify")) '取得该类别的最大编号

                If max > "" Then '如果存在最大编号

                    idx = CInt(max.Substring(12,3)) + 1 '获得最大编号的后三位顺序号,并加1

                Else

                    idx = 1 '否则顺序号等于1

                End If

                e.DataRow("周报编号") = lb & Format(idx,"000")

            End If

        End If

End Select


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


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

Select e.DataCol.Name
   
    Case "监造流水号"
       
        If e.DataRow.IsNull("监造流水号") Then
           
            e.DataRow("周报编号") = Nothing
           
        Else
           
            Dim lb As String = e.DataRow("监造流水号")  '生成编号的前缀
           
            Dim max As String
           
            Dim idx As Integer
           
            max = e.DataTable.Compute("Max(周报编号)","监造流水号 = '" & lb & "' And [_Identify] <> " & e.DataRow("_Identify")) '取得该类别的最大编号
           
            If max > "" Then '如果存在最大编号
               
                idx = CInt(max.Substring(lb.Length+1,3)) + 1 '获得最大编号的后三位顺序号,并加1
               
            Else
               
                idx = 1 '否则顺序号等于1
               
            End If
           
            e.DataRow("周报编号") = lb & "-" & Format(idx,"000")
           
        End If
       
End Select

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


加好友 发短信
等级:小狐 帖子:319 积分:2494 威望:0 精华:0 注册:2012/5/19 22:40:00
  发帖心情 Post By:2014/10/17 16:13:00 [只看该作者]

感谢甜版,经你提示,我琢磨了一下,还是我对例子中的每一条语句体会的不透彻,还要认真学习啊

 回到顶部