如何从SQL Server中检索YYYY-MM-DD格式的日期?我需要这个工作与SQL Server 2000及更高。是否有一个简单的方法来执行这在SQL Server或它会更容易转换后,我检索的结果集?
我已经阅读了微软Technet上的CAST和CONVERT,但我想要的格式没有列出,改变日期格式也不是一个选项。
如何从SQL Server中检索YYYY-MM-DD格式的日期?我需要这个工作与SQL Server 2000及更高。是否有一个简单的方法来执行这在SQL Server或它会更容易转换后,我检索的结果集?
我已经阅读了微软Technet上的CAST和CONVERT,但我想要的格式没有列出,改变日期格式也不是一个选项。
当前回答
使用每个转换/强制转换函数的CASE语句总是为我工作:
请将tableXXXXY替换为您的表名,并将issueDate_dat替换为该表中的datetime字段的名称:
SELECT issueDate_dat, CONVERT(varchar, DATEPART(yyyy, issuedate_dat)) AS issueDateYYYY
, CASE WHEN (len(CONVERT(varchar, DATEPART(mm, issuedate_dat))) < 2) THEN '0' +CONVERT(varchar, DATEPART(mm, issuedate_dat)) ELSE CONVERT(varchar, DATEPART(mm, issuedate_dat)) END AS issueDateMM
, CASE WHEN (len(CONVERT(varchar, DATEPART(dd, issuedate_dat))) <2) THEN '0' +CONVERT(varchar, DATEPART(dd, issuedate_dat)) ELSE CONVERT(varchar, DATEPART(dd, issuedate_dat)) END AS issueDateDD
FROM tableXXXXY
希望这对你有帮助。chagbert。
其他回答
我不知道为什么最简单的方法在上面的答案中被忽略了:
SELECT FORMAT(GetDate(),'yyyy-MM-dd');--= 2020-01-02
SELECT FORMAT(GetDate(),'dd MMM yyyy HH:mm:ss');-- = 02 Jan 2020 08:08:08
我更喜欢第二个,因为无论你说什么语言,你都知道今天是什么日子!
此外,当你将数据发送到保存过程时,SQL Server总是“理解”它,无论计算机中设置的是哪种区域格式——我在编程中总是使用全年(yyyy)、月名(MMM)和24小时格式(大写HH)来表示小时。
您所需要的表格在图书在线文档中列出。
http://msdn.microsoft.com/en-us/library/aa226054 (SQL.80) . aspx
例如,尝试以下方法:
select convert(varchar,getDate(),120)
select convert(varchar(10),getDate(),120)
由于字符串处理是昂贵的,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
我会用:
CONVERT(char(10),GETDATE(),126)
replace(convert(varchar, getdate(), 111), '/','-')
也会做戏法没有“砍任何东西”。