日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

用存储过程生成记录编号

發布時間:2025/4/16 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 用存储过程生成记录编号 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?

CREATE?procedure?up_GetBeautifulOrderNumber(@orderNumber?char(12)?out)
as
begin
declare?@number?char(11)--編號的后11位
declare?@maxDate?decimal--從數據庫表中當前最大的編號中取出的日期
declare?@currentDate?decimal????--當前日期
declare?@currentNumber?char(12)?--數據庫表中當前最大的編號
declare?@day?char(2)?--當前日期,如果是一位數,需要將其轉換為兩位數
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))+?'錯誤,數據庫表中紀錄的最大日期有錯誤,請與數據庫管理員聯系。'
?
raiserror(@errMessage,?16,?1)?
????
end
end
???
set?@orderNumber='B'+@number
end?

轉載于:https://www.cnblogs.com/jiangshaofen/archive/2007/04/13/711772.html

總結

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

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。