我将月份存储在SQL Server中为1,2,3,4,…12。我想把它们显示为一月,二月等。在SQL Server中有一个函数像MonthName(1) = 1月?如果可能的话,我尽量避免使用CASE语句。


当前回答

用最好的方式

Select DateName( month , DateAdd( month , @MonthNumber , -1 ))

其他回答

有点俗气,但应该有用:

SELECT DATENAME(month, DATEADD(month, @mydate-1, CAST('2008-01-01' AS datetime)))

用最好的方式

Select DateName( month , DateAdd( month , @MonthNumber , -1 ))

如果有人想在MySQL中得到同样的东西。请查看以下查询。

 SELECT MONTH(STR_TO_DATE('November', '%M'))

这样我得到了所要求的结果。

使用下面的语句获取月份名称:

DECLARE @date datetime
SET @date='2015/1/4 00:00:00'

SELECT CAST(DATENAME(month,@date )  AS CHAR(3))AS 'Month Name'

这将为您提供简短的月份名称。像这样:一月,二月,三月等。

select monthname(curdate());

OR

select monthname('2013-12-12');