Foxtable(狐表)用户栏目专家坐堂 → 为什么自动编号取得后四位 一直是0001 不累加


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

主题:为什么自动编号取得后四位 一直是0001 不累加

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


加好友 发短信
等级:婴狐 帖子:11 积分:161 威望:0 精华:0 注册:2017/8/28 9:30:00
为什么自动编号取得后四位 一直是0001 不累加  发帖心情 Post By:2017/9/6 16:37:00 [只看该作者]

为什么自动编号取得后四位 一直是0001 不累加

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


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

 贴出你写的代码。

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


加好友 发短信
等级:婴狐 帖子:11 积分:161 威望:0 精华:0 注册:2017/8/28 9:30:00
请看Word文件  发帖心情 Post By:2017/9/6 17:35:00 [只看该作者]

Select e.DataCol.Name

    Case "开工日期","工程项目简称"

        If e.DataRow.IsNull("开工日期") OrElse e.DataRow.IsNull("工程项目简称") Then

            e.DataRow("工程项目编号") = Nothing

        Else

            Dim d As Date = e.DataRow("开工日期")

            Dim y As Integer = d.Year

            Dim m As Integer = d.Month

            Dim Days As Integer = Date.DaysInMonth(y,m)

            Dim fd As Date = New Date(y,m,1) '获得该月的第一天

            Dim ld As Date = New Date(y,m,Days) '获得该月的最后一天

            Dim bh As String = e.DataRow("工程项目简称") & "-" & Format(d,"yyyyMM") & "-" '生成编号的前缀

        If e.DataRow("工程项目编号").StartsWith(bh) = False '如果工程项目编号前缀不符

                Dim max As String

                Dim idx As Integer

                Dim flt As String

                flt = "工程项目简称 = '"& e.DataRow("工程项目简称") & "' And 开工日期 >= #" & fd & "# And 开工日期 <= #" & ld & "# And [_Identify] <> " & e.DataRow("_Identify")

                max = e.DataTable.Compute("Max(工程项目编号)",flt) '取得该月的相同工程代码的最大工程项目编号

                If max > "" Then '如果存在最大工程项目编号

                   idx = CInt(max.Substring(19,4)) + 1 '获得最大工程项目编号的后四位顺序号,并加1

                Else

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

                End If

                e.DataRow("工程项目编号") = bh & Format(idx,"0000")

            End If

        End If

End Select


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


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

idx = CInt(max.Substring(19,4)) + 1 '获得最大工程项目编号的后四位顺序号,并加1

 

改成

 

idx = CInt(max.Substring(bh.length,4)) + 1 '获得最大工程项目编号的后四位顺序号,并加1


 回到顶部