Foxtable(狐表)用户栏目专家坐堂 → 按年月日自动编号的问题?


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

主题:按年月日自动编号的问题?

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


加好友 发短信
等级:四尾狐 帖子:972 积分:7193 威望:0 精华:0 注册:2013/5/24 12:29:00
按年月日自动编号的问题?  发帖心情 Post By:2016/7/6 0:48:00 [只看该作者]

如上案例,在帮助中学习到这一段代码?

If e.DataCol.Name = "日期" Then
    If e.DataRow.IsNull("日期") Then
        e.DataRow("编号") = Nothing
    Else
        Dim bh As String = Format(e.DataRow("日期"),"yyyyMMdd") '取得编号的8位前缀
        If e.DataRow("编号").StartsWith(bh) = False '如果编号的前8位不符
            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(9,3)) + 1 '获得最大编号的后三位顺序号,并加1
            Else
                idx = 1 '否则顺序号等于1
            End If
            e.DataRow("编号") = bh & "-" & Format(idx,"000")
        End If
    End If
End If
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:测试编号.table


求助能不能实现,一但编号完成则前面的日期列中的日期在怎么变,编号列中的编号不变,也就是说一次成型!但同时要保证编号列中的编号一定没有相同编号,那怕有几万或几十万条编号,不重号!求老师指点?

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


加好友 发短信
等级:狐神 帖子:5015 积分:25363 威望:0 精华:0 注册:2015/8/18 9:21:00
  发帖心情 Post By:2016/7/6 9:13:00 [只看该作者]

去掉日期的判断,直接取序号即可,类似

If e.DataCol.Name = "日期" Then
    If e.DataRow.IsNull("日期") Then
        e.DataRow("编号") = Nothing
    Else
        Dim bh As String = Format(e.DataRow("日期"),"yyyyMMdd") '取得编号的8位前缀
        
        Dim max As String
        Dim idx As Integer
        max = e.DataTable.Compute("Max(编号)"," [_Identify] <> " & e.DataRow("_Identify")) '取得该天的最大编号
        If max > "" Then '如果存在最大编号
            idx = CInt(max.Substring(9,3)) + 1 '获得最大编号的后三位顺序号,并加1
        Else
            idx = 1 '否则顺序号等于1
        End If
        e.DataRow("编号") = bh & "-" & Format(idx,"000")
    End If
    
End If

前提是顺序号要足够长,比如要达到千万级的数据,必须要8位顺序号,即Format(idx,"00000000")

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


加好友 发短信
等级:四尾狐 帖子:953 积分:7252 威望:0 精华:0 注册:2011/9/6 13:36:00
  发帖心情 Post By:2016/7/6 9:30:00 [只看该作者]

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:测试编号.table


 回到顶部