Foxtable(狐表)用户栏目专家坐堂 → [求助]自动编号


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

主题:[求助]自动编号

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


加好友 发短信
等级:小狐 帖子:385 积分:2918 威望:0 精华:0 注册:2018/1/15 15:01:00
[求助]自动编号  发帖心情 Post By:2019/1/31 16:39:00 [只看该作者]

我很纳闷,在表属性-打datacolchanged中设置了代码,想完成自动编号功能,结果自动编号出来都是**001,代码如下,请教了。
Select e.DataCol.Name
    Case "部门"
        If e.DataRow.IsNull("部门") Then
            e.DataRow("人员编号") = Nothing
        Else
            Dim lb As String = GetPinYin(e.DataRow("部门"),1)
            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

图片点击可在新窗口打开查看此主题相关图片如下:360截图165504228912895.png
图片点击可在新窗口打开查看
[此贴子已经被作者于2019/1/31 16:40:21编辑过]

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


加好友 发短信
等级:超级版主 帖子:110738 积分:563610 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/2/1 8:44:00 [只看该作者]

Select e.DataCol.Name
    Case "部门"
        If e.DataRow.IsNull("部门") Then
            e.DataRow("人员编号") = Nothing
        Else
            Dim lb As String = GetPinYin(e.DataRow("部门"),1)
            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(lb.Length,3)) + 1 '获得最大编号的后三位顺序号,并加1
                Else
                    idx = 1 '否则顺序号等于1
                End If
                e.DataRow("人员编号") = lb & Format(idx,"000")
            End If
        End If
End Select

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


加好友 发短信
等级:小狐 帖子:385 积分:2918 威望:0 精华:0 注册:2018/1/15 15:01:00
  发帖心情 Post By:2019/2/14 16:53:00 [只看该作者]

谢谢老师,我试一下。

 回到顶部