我将月份存储在SQL Server中为1,2,3,4,…12。我想把它们显示为一月,二月等。在SQL Server中有一个函数像MonthName(1) = 1月?如果可能的话,我尽量避免使用CASE语句。
当前回答
如果有人想在MySQL中得到同样的东西。请查看以下查询。
SELECT MONTH(STR_TO_DATE('November', '%M'))
这样我得到了所要求的结果。
其他回答
您可以使用内置的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以下是我的工作:
CAST(GETDATE() AS CHAR(3))
我认为当你有日期时,这足以得到月名。
SELECT DATENAME(month ,GETDATE())
用最好的方式
Select DateName( month , DateAdd( month , @MonthNumber , -1 ))
推荐文章
- 如何在Ruby On Rails中使用NuoDB手动执行SQL命令
- 查询JSON类型内的数组元素
- 确定记录是否存在的最快方法
- 获得PostgreSQL数据库中当前连接数的正确查询
- 在SQL选择语句Order By 1的目的是什么?
- 从现有模式生成表关系图(SQL Server)
- 我如何循环通过一组记录在SQL Server?
- 数据库和模式的区别
- 如何在SQL Server中一次更改多个列
- 如何从命令行通过mysql运行一个查询?
- 外键约束可能导致循环或多条级联路径?
- 使用LIMIT/OFFSET运行查询,还可以获得总行数
- 当恢复sql时,psql无效命令\N
- 货币应该使用哪种数据类型?
- 如何选择每一行的列值不是独特的