对平台函数【AccHelp_AutoID 自增序号函数 】的重写
时 间:2013-04-19 14:15:42
作 者:Aaron ID:20267 城市:闵行
摘 要: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群 (群号:321554481) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- Access对子窗体数据进行批...(10.30)
- 最精简的组合框行来源数据快速输...(10.25)
- Access仿平台的多值选择器...(10.24)
- 【Access日期区间段查询】...(10.22)
- 【Access源码示例】VBA...(10.12)
- Access累乘示例,Acce...(10.09)
- 数值8.88,把整数8去掉,转...(10.08)
- 【Access自定义函数】一个...(09.30)
- 【Access选项卡示例】Ac...(09.09)
学习心得
最新文章
- Access快速开发平台企业版--...(11.18)
- 不会用多表联合查询,多表查询没结果...(11.16)
- 【案例分享】主键字段值含有不间断空...(11.16)
- Access快速开发平台--后台D...(11.14)
- 微软Access邀测新Monaco...(11.12)
- Access列表框左右互选、列表框...(11.11)
- 高效率在导入数据前删除记录(11.10)
- Access报价单转订单示例代码(11.08)
- Access系统自带的日期选择器不...(11.08)
- 分享一下Access工程中的acw...(11.07)