Foxtable(狐表)用户栏目专家坐堂 → 这样的编号如何实现


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

主题:这样的编号如何实现

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


加好友 发短信
等级:四尾狐 帖子:867 积分:6210 威望:0 精华:0 注册:2012/11/24 20:44:00
这样的编号如何实现  发帖心情 Post By:2014/4/27 11:42:00 [只看该作者]

各位大师,有几种另类的编号,看如何实现:

固定前缀+日期(YYMMDD)或(YYMM)+流水号
1、例如每增加一行,产生一个前缀“B2014042801”的编号,前缀“B”为固定的,流水号如果是每月的如何做?

2、如果按年的流水号(即跨年后,流水号重新从001开始)。

3、如果一直流水下去,怎么处理?


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


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

参考,帮助里都有的。

 

http://www.foxtable.com/help/topics/2403.htm

 


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


加好友 发短信
等级:四尾狐 帖子:867 积分:6210 威望:0 精华:0 注册:2012/11/24 20:44:00
回复:(有点甜)参考,帮助里都有的。 http...  发帖心情 Post By:2014/4/27 23:42:00 [只看该作者]

如何实现在日期前加“B”字母,且日期为YYMMDD,后面流水一年才重新开始?
图片点击可在新窗口打开查看此主题相关图片如下:2.jpg
图片点击可在新窗口打开查看


代码哪儿错了?
If e.DataCol.Name = "报备日期" Then
    If 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 S As String = "BCDEF".ToUpper
        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 = Format(d,"yyyyMM") '生成编号的前6位,4位年,2位月.
        If e.DataRow("报备单号").StartsWith(bh) = False '如果编号的前6位不符
            Dim max As String
            Dim idx As Integer
            max = e.DataTable.Compute("Max(报备单号)","报备日期 >= #" & fd & "# And 报备日期 <= #" & ld & "# And [_Identify] <> " & e.DataRow("_Identify")) '取得该月的最大编号
            If max > "" Then '如果存在最大编号
                idx = CInt(max.Substring(7,3)) + 1 '获得最大编号的后三位顺序号,并加1
            Else
                idx = 1 '否则顺序号等于1
            End If
            e.DataRow("报备单号") = S.SubString(0,1) & bh & Format(idx,"000")
        End If
    End If
End If


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


加好友 发短信
等级:三尾狐 帖子:635 积分:6336 威望:0 精华:0 注册:2011/5/8 13:21:00
  发帖心情 Post By:2014/4/27 23:59:00 [只看该作者]

If e.DataCol.Name = "报备日期" Then
    If 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 = "B" & Format(d,"yyyyMM") '生成编号的前6位,4位年,2位月.
        If e.DataRow("报备单号").StartsWith(bh) = False '如果编号的前6位不符
            Dim max As String
            Dim idx As Integer
            max = e.DataTable.Compute("Max(报备单号)","报备日期 >= #" & fd & "# And 报备日期 <= #" & ld & "# And [_Identify] <> " & e.DataRow("_Identify")) '取得该月的最大编号
            If max > "" Then '如果存在最大编号
                idx = CInt(max.Substring(7,3)) + 1 '获得最大编号的后三位顺序号,并加1
            Else
                idx = 1 '否则顺序号等于1
            End If
            e.DataRow("报备单号") = bh & Format(idx,"000")
        End If
    End If
End If
 
不知道楼主怎么想的,上面的应该可以!
[此贴子已经被作者于2014-4-27 23:59:56编辑过]

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


加好友 发短信
等级:四尾狐 帖子:867 积分:6210 威望:0 精华:0 注册:2012/11/24 20:44:00
回复:(lhpc120)If e.DataCol.Name = "报备日期" Th...  发帖心情 Post By:2014/4/28 10:06:00 [只看该作者]

这个基本可能了,如果以下的想法如何实现:

1、把前缀的“YYYYMM”改为“YYYYMMDD”,如何实现?

2、把流水号由现在的每月重新开始,改为每年重新开始,如原来每月从“001”开始,改为一年一次从“001”开始,直到次年1月,又从“001”号流水开始,如何做?

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


加好友 发短信
等级:贵宾 帖子:35433 积分:178524 威望:0 精华:3 注册:2013/3/30 16:36:00
  发帖心情 Post By:2014/4/28 10:08:00 [只看该作者]

1.
Dim bh As String = "B" & Format(d,"yyyyMMdd")

2.
Dim y As Integer = d.Year
 Dim fd As Date = New Date(y,2,1) '获得该年的第一天
        Dim ld As Date = New Date(y+1,1,31) '获得该年的最后一天
[此贴子已经被作者于2014-4-28 10:12:48编辑过]

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


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

这样改一下便可

 

If e.DataCol.Name = "报备日期" Then
    If 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 fd As Date = New Date(y,m,1) '获得该月的第一天
        Dim ld As Date = New Date(y+1,m,1) '获得该月的最后一天
        Dim bh As String = "B" & Format(d,"yyyyMMdd")
        If e.DataRow("报备单号").StartsWith(bh) = False '如果编号的前6位不符
            Dim max As String
            Dim idx As Integer
            max = e.DataTable.Compute("Max(报备单号)","报备日期 >= #" & fd & "# And 报备日期 < #" & ld & "# And [_Identify] <> " & e.DataRow("_Identify")) '取得该月的最大编号
            If max > "" Then '如果存在最大编号
                idx = CInt(max.Substring(bh.Length,3)) + 1 '获得最大编号的后三位顺序号,并加1
            Else
                idx = 1 '否则顺序号等于1
            End If
            e.DataRow("报备单号") = bh & Format(idx,"000")
        End If
    End If
End If

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


加好友 发短信
等级:四尾狐 帖子:867 积分:6210 威望:0 精华:0 注册:2012/11/24 20:44:00
回复:(Bin)1.Dim bh As String = "B" & Format...  发帖心情 Post By:2014/4/28 11:35:00 [只看该作者]

谢谢大师

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


加好友 发短信
等级:四尾狐 帖子:867 积分:6210 威望:0 精华:0 注册:2012/11/24 20:44:00
回复:(有点甜)这样改一下便可 If e.DataC...  发帖心情 Post By:2014/4/28 11:36:00 [只看该作者]

谢谢大师,有你们才有我们的进步

 回到顶部