Access开发培训
网站公告
·Access专家课堂QQ群号:151711184    ·Access快速开发平台下载地址及教程    ·欢迎加入Access专家课堂微信群!    ·如何快速搜索本站文章|示例|资料    
您的位置: 首页 > 技术文章 > Access数据库-模块/函数/VBA

【access源码示例】高效无重复自动编码解决方案

时 间:2011-01-30 00:00:00
作 者:红尘如烟   ID:10768  城市:成都
摘 要:效率非常高的无重复自动编码解决方案
正 文:

    一般自动编号功能,是先取得表中的已有最大号,然后在此基础上加1,如果每次生成编号都要从表中去取得最大编号,也就意味着每次生成编号都需要查询表中所有的记录,如果表中数据量很大,如有十万条以上,那么性能就很差了。(当然数据库引擎会有优化,但再优化总归是有限的)。并且这种方法在多用户同时录入时,存在生成重复编号的问题。

    本示例采用的方式为:调用GetNewID函数时,从编码表(USysSN)中读取指定编号字段对应的编号记录,如果记录为空,则先从原表中读取最大编号写入到该记录中;如果记录不为空,则读取该记录中的编号,并加1生成新编号,同时将编码表中的编号更新为新生成的编号。这样每次生成编号时只需要查询编码表中的很少的记录即可,并且由于生成的编号和原表无关,还可以防止多用户同时录入时生成重复编号的问题。

    假设某个表中有10万条记录,那么直接读取表生成新编号的方式需要查询10万条记录,而使用编码表的方式则每次只需要查询编码表中的几十条记录。

'============================================================================================================================
'-函数名称:    GetNewID
'-功能描述:    高效率的文本型自动编号函数,除了第一次调用,以后每次生成编号时不需要再访问编号字段所在的表,因此效率非常高,
'               表中数据量越大,效果越明显。并且在多用户环境下,也不会出现多个用户基于一个表同时录入时,会出现的编号重复问
'               题。适用于各种单据的编号及流水码等,具体请参考使用示例。
'-输入参数:    TableName       必需的,表名称或查询名称。
'               FieldName       必需的,自动编号字段名。
'               Digit           必需的,不包含前缀的序号位数。
'               Prefixal        可选的,编号前缀字符串,除了单据类型的描述字符,还可以把其它信息要素如部门ID等加入到此参数中。
'               DateFormat      可选的,编号中的日期部分格式,具体使用请参考Format函数中关于日期的数的部分说明。
'-其它说明:    必需要有一个编号维护表配合使用,表名称:USysSN 字段名:TableName|FieldName|LastID ,3个字段均为文本型,大小255。
'-使用注意:
'-返回参数:    返回生成的编号,出错时返回空字符串("")。
'-兼 容 性:
'-使用示例:    =GetNewID("Orders","OrderID",5,"XS","yymmdd")     返回示例:XS01042500004
'               =GetNewID("Orders","OrderID",5,"XS","-yyyymmdd-") 返回示例:XS-20100425-00004
'               =GetNewID("Orders","OrderID",5,"XS")              返回示例:XS00004
'               =GetNewID("Orders","OrderID",5,"XS","-")          返回示例:XS-00004
'               =GetNewID("Orders","OrderID",5)                   返回示例:00004
'               =GetNewID("Orders","OrderID",5,"【售】")          返回示例:【售】00004
'-相关调用:
'-作    者:    红尘如烟
'-创建日期:    2011-1-25
'=============================================================================================================================

Function GetNewID(TableName As String, FieldName As String, Digit As Integer, _
                    Optional Prefixal As String, Optional DateFormat As String) As String
    On Error GoTo Err_GetNewID
    Dim strDate     As String
    Dim strLastID   As String
    Dim strSN       As String
    Dim strWhere    As String
   
    If DateFormat <> "" Then strDate = Format$(Date, DateFormat)
    strSN = String$(Digit, "0")
    strWhere = "TableName='" & TableName & "' AND FieldName='" & FieldName & "'"
    strLastID = Nz(DLookup("LastID", "USysSN", strWhere))
   
    If strLastID = "" Then
        strLastID = Nz(DMax(FieldName, TableName), strSN)
        CurrentDb.Execute "Delete FROM USysSN Where " & strWhere
        CurrentDb.Execute "Insert INTO USysSN(TableName,FieldName) " & _
                          "VALUES('" & TableName & "','" & FieldName & "')"
    End If
   
    strLastID = Prefixal & strDate & Format$(Val(Right$(strLastID, Digit)) + 1, strSN)
    CurrentDb.Execute "Update USysSN SET LastID='" & strLastID & "' Where " & strWhere
    GetNewID = strLastID
   
Exit_GetNewID:
    Exit Function
   
Err_GetNewID:
    GetNewID = ""
    MsgBox Err.Description, vbCritical, "Error #" & Err
    Resume Exit_GetNewID
End Function


点击下载此附件

Access软件网QQ交流群 (群号:54525238)       Access源码网店

常见问答:

技术分类:

相关资源:

专栏作家

关于我们 | 服务条款 | 在线投稿 | 友情链接 | 网站统计 | 网站帮助