分享
 
 
 

用数据库生成不重复的流水号

王朝other·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

'*************************************************

'函数名:getMaxOrder

'作 用:得到最大序列号

'参 数:fieldName ----在序列号表中的字段名

' tableName ----序列号所在表名

' fieldName ----在表中的字段名

'返回值:字段的最大值

'调用函数:idAdd:作用见上

'*************************************************

function getMaxOrder(fieldName,tableName,tableFileName)

dim orderNO,orderRS,testRS

set testRS=Server.CreateObject("ADODB.recordset")

set orderRS=Server.CreateObject("ADODB.recordset")

firstNO=year(date)&right(("0"&month(date)),2)

orderSQL="select * from fieldMaxValue where fieldName='"&fieldName&"'"

orderRS.open orderSQL,conn,3,2

if not orderRS.eof then

orderRS("fieldMaxValue")=orderRS("fieldMaxValue")

orderNO=orderRS("fieldMaxValue")

if left(orderNO,6)=firstNO then

orderNO=idAdd(orderNO)

else

orderNO=firstNO&"00001"

end if

else

orderRS.addnew

orderRS("fieldName")=fieldName

orderNO=firstNO&"00001"

end if

testRS.open "select max("&tableFileName&") from "&tableName&" where "&tableFileName&" like '"&firstNO&"%'",conn,1,2

if (not testRS.eof) and testRS(0).value>orderNO then

orderNO=idAdd(testRS(0).value)

end if

testRS.close

set testRS=nothing

orderRS("fieldMaxValue")=orderNO

orderRS.update

orderRS.close

set orderRS=nothing

getMaxOrder=orderNO

end function

'*************************************************

'函数名:idAdd

'作 用:用来增加一:比如idAdd("5")="6",idAdd("L99")="M00",idAdd("!")="!1"

' 如果是数字就到9后进位,如果是小写字母到期z后进位

' 如果是大写字母到Z后进位,其它在后面加一个1

'参 数:id ----需来增加的数

'返回值:增加后的数

'调用函数:addOne 一个数增加一 AddOne("5")="6",Add(9)="0",AddOne("a")="b",

' AddOne("z")="a",AddOne("A")="B",AddOne("Z")="A"

'*************************************************

Function AddOne(first)

Dim tempfirst

AddOne = first

intfirst = Asc(first)

If (intfirst >= 48 And intfirst < 57) Or (intfirst >= 65 And intfirst < 90) Or (intfirst >= 97 And intfirst < 122) Then

AddOne = Chr(intfirst + 1)

Exit Function

End If

If (intfirst = 57) Then

AddOne = "0"

Exit Function

End If

If (intfirst = 90) Then

AddOne = "A"

Exit Function

End If

If (intfirst = 122) Then

AddOne = "a"

Exit Function

End If

End Function

Function idAdd(id)

Dim fornt, back, strFind, strBackFind, idLen, tempid

if id="" or isNull(id) then

iddAdd=1

exit Function

end if

tempid = id

idLen = Len(id)

For i = 1 To idLen

fornt = Left(id, idLen - i)

back = Right(id, i - 1)

strFind = Mid(id, idLen + 1 - i, 1)

strBackFind = AddOne(strFind)

id = fornt & strBackFind & back

If strFind < strBackFind Then

Exit For

End If

If strFind > strBackFind Then

If i = idLen Then

id = id & "1"

Else

If Mid(id, idLen - i, 1) = AddOne(Mid(id, idLen - i, 1)) Then

id = fornt & strBackFind & back & "1"

Exit For

End If

End If

End If

Next

If id = tempid Then

id = id & "1"

End If

idAdd = id

End Function

'调用示例

serviceNO=getMaxOrder("serviceNO","service","serviceNO")

'其中保存所有字段流水号最大值的表的结构为:

表名:fieldMaxValue

字段

id fieldName fieldMaxValue

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有