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


当前回答

有点俗气,但应该有用:

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

其他回答

我认为当你有日期时,这足以得到月名。

SELECT DATENAME(month ,GETDATE())

您可以使用内置的CONVERT函数

select CONVERT(varchar(3), Date, 100)  as Month from MyTable.

这将显示一个月的前3个字符(JAN,FEB等)。

您可以创建一个这样的函数来生成Month和do SELECT dbo.fn_GetMonthFromDate(date_column)作为月份FROM table_name /******对象:UserDefinedFunction [dbo]。[fn_GetMonthFromDate]脚本日期:11/16/2018 10:26:33 AM ******/ 设置ansi_nulls为on 去 设置quoted_identifier为on 去 CREATE FUNCTION [dbo].[fn_GetMonthFromDate] (@date datetime) 返回varchar (50) 作为 开始 声明@monthPart int

SET @monthPart = MONTH(@date) IF @monthPart = 1 BEGIN RETURN 'January' END ELSE IF @monthPart = 2 BEGIN RETURN 'February' END ELSE IF @monthPart = 3 BEGIN RETURN 'March' END ELSE IF @monthPart = 4 BEGIN RETURN 'April' END ELSE IF @monthPart = 5 BEGIN RETURN 'May' END ELSE IF @monthPart = 6 BEGIN RETURN 'June' END ELSE IF @monthPart = 7 BEGIN RETURN 'July' END ELSE IF @monthPart = 8 BEGIN RETURN 'August' END ELSE IF @monthPart = 9 BEGIN RETURN 'September' END ELSE IF @monthPart = 10 BEGIN RETURN 'October' END ELSE IF @monthPart = 11 BEGIN RETURN 'November' END ELSE IF @monthPart = 12 BEGIN RETURN 'December' END RETURN NULL END

这很简单。

select DATENAME(month, getdate())

产出:1月

使用此语句将月份数值转换为月份名称。

SELECT CONVERT(CHAR(3), DATENAME(MONTH, GETDATE()))