以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.com/bbs/index.asp)
--  专家坐堂  (http://foxtable.com/bbs/list.asp?boardid=2)
----  自动编号  (http://foxtable.com/bbs/dispbbs.asp?boardid=2&id=161277)

--  作者:5301zsz
--  发布时间:2021/3/11 21:19:00
--  自动编号
老师好,自动编号不行,请看哪里出错。
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:管理项目1.foxdb

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(2,3)) + 1 \'获得最大编号的后三位顺序号,并加1
                Else
                    idx = 1 \'否则顺序号等于1
                End If
                e.DataRow("设备资料_设备编号") = lb & Format(idx,"000")
            End If
        End If
End Select

--  作者:有点蓝
--  发布时间:2021/3/11 21:25:00
--  
idx = CInt(max.Substring(2,3)) + 1
改为
idx = CInt(max.Substring(max.Length - 3)) + 1 

--  作者:5301zsz
--  发布时间:2021/3/12 9:08:00
--  
收到,谢谢老师!