日期轉換為中文大寫
作者:張勇波
博主發(fā)表的文章,有的是自己原創(chuàng),有的是這些年本人從網(wǎng)上積累的,方便大家學習。
- ALTER FUNCTION GetCNDay
- (
- @dt
- )
- RETURNS Nvarchar(50)
- AS
- BEGIN
- DECLARE @str Nvarchar(50) -- 中間字符串,用于存儲***次轉換之后的日期字符
- DECLARE @Year Int,@Month Int,@Day Int -- 獲取函數(shù)傳入的時間參數(shù)的年月日的值
- DECLARE @strYear Nvarchar(50),@strMonth Nvarchar(50),@strDay Nvarchar(50) -- 中間字符串,分別用于存儲***次轉換之后的年月日字符串
- declare @e Nvarchar(10),@n Nvarchar(10),@index Int,@result Nvarchar(50) -- @e,@n和@index用于字符串比對,將@e中@index位置出現(xiàn)的字符替換成@n中@index位置的字符,@result用于存儲最終處理完成的日期字符串,并作為返回結果
- SELECT @e='0123456789',@n='〇一二三四五六七八九',@index=1
- SET @Year = Year(@dt)
- SET @Month = Month(@dt)
- SET @Day = Day(@dt)
- -- 生成年
- SET @strYear = Cast(@Year AS Nvarchar(50)) + '年'
- -- 生成月
- IF(@Month < 10)
- SET @strMonth = Cast(@Month AS Nvarchar(50))
- ELSE IF(@Month = 10)
- SET @strMonth = '十'
- ELSE IF(@Month > 10)
- SET @strMonth = '十' + Cast((@Month - 10) AS Nvarchar(50))
- SET @strMonth = @strMonth + '月'
- -- 生成日
- IF(@Day < 10)
- SET @strDay = Cast(@Day AS Nvarchar(50))
- ELSE IF(@Day = 10)
- SET @strDay = '十'
- ELSE IF(@Day > 10 AND @Day < 20)
- SET @strDay = '十' + Cast((@Day - 10) AS Nvarchar(50))
- ELSE IF(@Day = 20)
- SET @strDay = '二十'
- ELSE IF(@Day > 20 AND @Day < 30)
- SET @strDay = '二十' + Cast((@Day - 20) AS Nvarchar(50))
- ELSE IF(@Day = 30)
- SET @strDay = '三十'
- ELSE IF(@Day = 31)
- SET @strDay = '三十一'
- SET @strDay = @strDay + '日'
- -- 拼接年月日
- SET @str = @strYear + @strMonth + @strDay
- WHILE @index<=Len(@str)
- BEGIN
- DECLARE @s Nvarchar(1)
- SET @s=SubString(@str,@index,1)
- IF CharIndex(@s,@e)>0
- SET @result=IsNull(@result,'')+SubString(@n,CharIndex(@s,@e),1)
- ELSE
- SET @result=IsNull(@result,'')+@s
- SET @index=@index+1
- END
- RETURN @result
- END
- GO
【本文是51CTO專欄作者張勇波的原創(chuàng)文章,轉載請通過51CTO獲取作者授權】
責任編輯:武曉燕
來源:
上下求索的Z先生博客