对平台函数【AccHelp_AutoID 自增序号函数 】的重写-Aaron
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> Access开发平台


对平台函数【AccHelp_AutoID 自增序号函数 】的重写

发表时间:2013/4/19 14:15:42 评论(4) 浏览(7868)  评论 | 加入收藏 | 复制
   
摘 要:AccHelp_AutoID 自增序号函数 
功能: AccHelp_AutoID函数可用于自动编号,例如: B00001 B00002 B00003
 
但是在很多时候,编码的前缀是变化的,例如前缀代表分类信息。这个时候自增段,就要根据编码来重新计数,而不是根据整个表的记录条数来计数的。
所以对系统的函数进行了重写:
正 文:

AccHelp_AutoID 自增序号函数

    功能: AccHelp_AutoID函数可用于自动编号,例如: B00001 B00002 B00003

但是在很多时候,编码的前缀是变化的,例如前缀代表分类信息。这个时候自增段,就要根据编码来重新计数,而不是根据整个表的记录条数来计数的。

所以对系统的函数进行了重写:

加入到一个模块中,声明为Public类型函数即可。

'////////////////////////////////////////////////////////////////////////
'///////////
'//函数名:AutoPrefixCode
'//编写者:Aaron Dong
'//参考资料:
'//功能:自动生成带前缀的编号
'//输入参数:Prefix:编号前缀;字符型
'                   NumberLength:自增数字段位数;数字型
'                   TableName: 表名称; 字符型
'                   FieldName:字段名称; 字符型
'                   BasedOnPrefix:递增段是否基于前缀; 布尔型
'//输出参数:自动生成的编号:字符类型
'//备注:
'///////////
'////////////////////////////////////////////////////////////////////////
Public Function AutoPrefixCode(PreFix As String, NumberLength As Integer, TableName As String, FieldName As String, BasedOnPrefix As Boolean) As String
    Dim strMax As String
    Dim strFormat As String
    Dim i As Integer
    strMax = FieldName
    '//如果编码的计数基于前缀
    If BasedOnPrefix Then
        For i = 1 To NumberLength
            strFormat = strFormat & "0"
        Next
        AutoPrefixCode = Nz(DMax(strMax, TableName, FieldName & " LIKE '" & PreFix & "*'"), "")
        If Len(AutoPrefixCode) = 0 Then

            AutoPrefixCode = PreFix & Format("1", strFormat)
        Else
            AutoPrefixCode = PreFix & Format(CLng(Replace(AutoPrefixCode, PreFix, "")) + 1, strFormat)
        End If
    '//如果编码的计数不基于前缀
    Else
        AutoPrefixCode = acchelp_autoid(PreFix, NumberLength, TableName, FieldName)
    End If
End Function





Access软件网交流QQ群(群号:198465573)
 
 相关文章
UMV自增序号的函数源码Acchelp_AutoID  【bamboo  2008/1/29】
UMV企业版的学习之 Acchelp_StrDataIsExist...  【李双军  2008/3/1】
按类别自动编号函数AccHelp_AutoSortID  【竹笛  2009/3/24】
判断一个表中某个字段中是否存在某个值的Acchelp_ValueI...  【竹笛  2009/7/31】
通过代码重新引用access开发平台代码库acchelp.umv文...  【jlbaccess  2010/8/21】
umv开发平台通用编号函数AccHelp_AutoID修改  【金宇  2012/3/1】
自增序号的函数源码Acchelp_AutoID  【小英  2013/1/31】
常见问答
技术分类
相关资源
文章搜索
关于作者

Aaron

文章分类

文章存档

友情链接