如何从SQL Server中检索YYYY-MM-DD格式的日期?我需要这个工作与SQL Server 2000及更高。是否有一个简单的方法来执行这在SQL Server或它会更容易转换后,我检索的结果集?

我已经阅读了微软Technet上的CAST和CONVERT,但我想要的格式没有列出,改变日期格式也不是一个选项。


当前回答

SELECT CONVERT(char(10), GetDate(),126)

限制您不想要的小时部分的varchar排骨的大小。

其他回答

Select convert (nvarchar (20), getdate (), 23)

从SQL Server 2012开始(最初的问题是2000年的):

选择格式(GetDate),“yyy- eddd”)

由于字符串处理是昂贵的,FORMAT更是如此,我很惊讶Asher/Aaron Dietz的响应不是更高,如果不是顶级的;问题是寻找ISO 8601日期,并没有特别要求它作为字符串类型。

最有效的方法可能是以下任何一种(为了完整起见,我已经包括了Asher/Aaron Dietz提出的答案):

所有版本

select  cast(getdate() as date)
select  convert(date, getdate())

2008年及以上

select  convert(date, current_timestamp)

ANSI SQL等效2008和更高

select  cast(current_timestamp as date)

引用:

https://sqlperformance.com/2015/06/t-sql-queries/format-is-nice-and-all-but

https://en.wikipedia.org/wiki/ISO_8601

https://www.w3schools.com/sql/func_sqlserver_current_timestamp.asp

https://learn.microsoft.com/en-us/sql/t-sql/functions/current-timestamp-transact-sql?view=sql-server-ver15

以防有人想用另一种方式来做,发现了这个。

select convert(datetime, '12.09.2014', 104)

这将德国日期格式的字符串转换为datetime对象。

为什么是104年?请看这里:http://msdn.microsoft.com/en-us/library/ms187928.aspx

在你的强制转换链接中,使用样式126:

CONVERT (varchar(10), DTvalue, 126)

这缩短了时间。您要求它在yyyy-mm-dd中,这意味着它必须是字符串数据类型和日期时间。

坦率地说,除非你有充分的理由不这么做,否则我会在客户端上这么做。