asp中用數(shù)據(jù)庫生成不重復(fù)的流水號(hào)
更新時(shí)間:2006年09月03日 00:00:00 作者:
asp中用數(shù)據(jù)庫生成不重復(fù)的流水號(hào)的實(shí)現(xiàn)代碼,需要的朋友可以參考下實(shí)現(xiàn)原理其它程序一樣。
復(fù)制代碼 代碼如下:
'*************************************************
'函數(shù)名:getMaxOrder
'作 用:得到最大序列號(hào)
'參 數(shù):fieldName ----在序列號(hào)表中的字段名
' tableName ----序列號(hào)所在表名
' fieldName ----在表中的字段名
'返回值:字段的最大值
'調(diào)用函數(shù):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
'*************************************************
'函數(shù)名:idAdd
'作 用:用來增加一:比如idAdd("5")="6",idAdd("L99")="M00",idAdd("!")="!1"
' 如果是數(shù)字就到9后進(jìn)位,如果是小寫字母到期z后進(jìn)位
' 如果是大寫字母到Z后進(jìn)位,其它在后面加一個(gè)1
'參 數(shù):id ----需來增加的數(shù)
'返回值:增加后的數(shù)
'調(diào)用函數(shù):addOne 一個(gè)數(shù)增加一 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
'調(diào)用示例
serviceNO=getMaxOrder("serviceNO","service","serviceNO")
'其中保存所有字段流水號(hào)最大值的表的結(jié)構(gòu)為:
表名:fieldMaxValue
字段
id fieldName fieldMaxValue
相關(guān)文章
asp二維數(shù)組實(shí)例中的使用方法總結(jié)
筆者對asp編程不是很熟悉,而且好長不用記不清了。這一次,需要保存asp的二維數(shù)組為asp文件,使用include 指令文件引用后,直接調(diào)用。使用過程中發(fā)現(xiàn)asp的二維數(shù)組相關(guān)資料很少,而且介紹簡單模糊,現(xiàn)結(jié)合使用實(shí)例做個(gè)簡單筆記。2023-06-06ASP是使用正則提取內(nèi)容里所有圖片路徑SRC的實(shí)現(xiàn)代碼
有時(shí)候客戶提交的內(nèi)容里包含多個(gè)圖片,客戶想單獨(dú)把圖片路徑提取出來進(jìn)行保存,下面腳本之家小編跟大家分享ASP正則提取內(nèi)容里所有圖片路徑SRC的方法函數(shù),需要的朋友可以參考下2019-09-09asp簡單生成靜態(tài)的方法(模板標(biāo)簽替換)
asp簡單生成靜態(tài)的方法,今天看了詞典工具里面的代碼,比較簡單,需要的朋友可以參考下。2011-03-03Dom遍歷XML的一個(gè)例子,結(jié)果為樹狀結(jié)構(gòu)
Dom遍歷XML的一個(gè)例子,結(jié)果為樹狀結(jié)構(gòu)...2007-01-01GetPaing 函數(shù)之a(chǎn)sp采集函數(shù)中用到的獲取分頁的代碼
GetPaing 函數(shù)之a(chǎn)sp采集函數(shù)中用到的獲取分頁的代碼...2007-09-09