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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

sql server 按照日期自动生成单据编号的函数

發布時間:2025/3/11 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 sql server 按照日期自动生成单据编号的函数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、sql server 按照日期自動生成單據編號的函數,格式為##08080001,##表示打頭的單據字符,然后是年月和流水編號。
二、傳入的參數為單據的打頭字符和生成單據的日期
三、一般的調用格式為dbo.GetCostBillID('HP',getdate())

--按單號和年月獲取單據的編號 CREATE FUNCTION GetCostBillID(@headStr nvarchar(10),@date datetime) RETURNS nvarchar(50) BEGIN declare @oid2 nvarchar(50) declare @oid nvarchar(50) declare @month nvarchar(2) declare @year nvarchar(2) declare @ym nvarchar(4) set @month=month(@date) if len(@month)=1set @month='0'+@month --使月為兩位長 set @year=right(convert(nvarchar,year(@date)),2) set @ym=@year+@month --組成年月字符--格式CB0808001 if exists(select * from CostBill) beginselect top 1 @oid2=CostBillID from CostBill order by id desc --獲取最后一條的單據編號,一定要有id,并且自動生成的,倒排序 end else beginset @oid2=@headStr+@ym+'0000' --沒有記錄是默認為今天 end--訂單不是本月的,重新開始一個新的訂單流水號 if convert(nvarchar,left(@oid2,6))<>@headStr+@ym begin --用本月的年月號開始set @oid2=@headStr+@ym+'0000' enddeclare @str nvarchar(50) --臨時單號set @str=convert(nvarchar,(convert(int,right(@oid2,4))+1)) --訂單號加一 while (4-len(@str)>0) beginset @str='0'+@str end set @oid2=@headStr+@ym+@str --print @oid2--如果該訂單好已經存在,則重新獲取 while exists(select * from CostBill where CostBillID=@oid2) beginset @str=convert(nvarchar,(convert(int,right(@oid2,4))+1)) --訂單號加一while (4-len(@str)>0)beginset @str='0'+@str endset @oid2=@headStr+@ym+@str -- print @oid2 endset @oid=convert(nvarchar,@oid2) --print 'HP'+convert(nvarchar,year(getdate()))+convert(nvarchar,month(getdate()))+@strRETURN @oid END

?

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的sql server 按照日期自动生成单据编号的函数的全部內容,希望文章能夠幫你解決所遇到的問題。

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