我将月份存储在SQL Server中为1,2,3,4,…12。我想把它们显示为一月,二月等。在SQL Server中有一个函数像MonthName(1) = 1月?如果可能的话,我尽量避免使用CASE语句。
当前回答
您可以使用内置的CONVERT函数
select CONVERT(varchar(3), Date, 100) as Month from MyTable.
这将显示一个月的前3个字符(JAN,FEB等)。
其他回答
为我工作
SELECT MONTHNAME(<fieldname>) AS "Month Name" FROM <tablename> WHERE <condition>
有点俗气,但应该有用:
SELECT DATENAME(month, DATEADD(month, @mydate-1, CAST('2008-01-01' AS datetime)))
SELECT MONTHNAME(concat('1970-',[Month int val],'-01'))
例如- SELECT MONTHNAME(concat('1970-',4,'-01'))
答案是——四月
下面是我利用别人的信息来解决问题的方法。
datename(month,dateadd(month,datepart(month,Help_HelpMain.Ticket_Closed_Date),-1)) as monthname
在希伯来语等一些语言环境中,闰月取决于年份,因此为了避免在这些语言环境中出现错误,您可以考虑以下解决方案:
SELECT DATENAME(month, STR(YEAR(GETDATE()), 4) + REPLACE(STR(@month, 2), ' ', '0') + '01')