日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

用存储过程生成记录编号

發(fā)布時(shí)間:2025/4/16 59 豆豆
生活随笔 收集整理的這篇文章主要介紹了 用存储过程生成记录编号 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

?

CREATE?procedure?up_GetBeautifulOrderNumber(@orderNumber?char(12)?out)
as
begin
declare?@number?char(11)--編號的后11位
declare?@maxDate?decimal--從數(shù)據(jù)庫表中當(dāng)前最大的編號中取出的日期
declare?@currentDate?decimal????--當(dāng)前日期
declare?@currentNumber?char(12)?--數(shù)據(jù)庫表中當(dāng)前最大的編號
declare?@day?char(2)?--當(dāng)前日期,如果是一位數(shù),需要將其轉(zhuǎn)換為兩位數(shù)
set?@day=(select?case?len(datename(d,getdate()))?
?
when?1?then?'0'+?cast(datename(d,getdate())?as?char(1))
?
when?2?then?cast(datename(d,getdate())?as?char(2))?end)
set?@currentDate=cast((datename(yyyy,getdate())+datename(mm,getdate())+?@day)?as?decimal)
if?not?exists(select?top?1?OrderID?from?Orders?order?by?OrderID?desc)
begin
?
set?@number=cast((@currentDate?*1000)?as?char(11))
end
else?
begin
??
set?@currentNumber=(select?top?1?OrderID?from?Orders?order?by?OrderID?desc)
??
set?@maxDate=cast(substring(@currentNumber,?2,8)?as?decimal)
??
if?@maxDate<@currentDate?
????
begin
?
set?@number=cast(@currentDate?*1000?as?char(11))
????
end
??
else?if?@maxDate=@currentDate
????
begin
?
set?@number=cast((cast(substring(@currentNumber,2,12)?as?decimal)+1)?as?char(11))
????
end
??
else?
????
begin
?
print?@maxDate
?
declare?@errMessage?varchar(100)
?
set?@errMessage=cast(@maxDate?as?char(10))+?'錯(cuò)誤,數(shù)據(jù)庫表中紀(jì)錄的最大日期有錯(cuò)誤,請與數(shù)據(jù)庫管理員聯(lián)系。'
?
raiserror(@errMessage,?16,?1)?
????
end
end
???
set?@orderNumber='B'+@number
end?

轉(zhuǎn)載于:https://www.cnblogs.com/jiangshaofen/archive/2007/04/13/711772.html

總結(jié)

以上是生活随笔為你收集整理的用存储过程生成记录编号的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。