select * from sampleTable where CONVERT(VARCHAR(20),DateCreated,101) = CONVERT(VARCHAR(20),CAST('Feb 15 2012 7:00:00:000PM' AS DATETIME),101)
我想没有时间比较日期
解决方法
不要使用转换 – 无缘无故地涉及字符串.一个技巧是日期时间实际上是一个数字,而日期是整数部分(时间是小数部分);因此,这一天是价值的FLOOR:这只是数学,而不是字符串 – 更快
declare @when datetime = GETUTCDATE() select @when // date + time declare @day datetime = CAST(FLOOR(CAST(@when as float)) as datetime) select @day // date only
在您的情况下,无需转换回日期时间;并使用范围允许最有效的比较(特别是如果索引):
declare @when datetime = 'Feb 15 2012 7:00:00:000PM' declare @min datetime = FLOOR(CAST(@when as float)) declare @max datetime = DATEADD(day,1,@min) select * from sampleTable where DateCreated >= @min and DateCreated < @max