在SQL Server中从datetime字段中删除时间部分时,哪种方法提供了最佳性能?

a) select DATEADD(dd, DATEDIFF(dd, 0, getdate()), 0)

or

b) select cast(convert(char(11), getdate(), 113) as datetime)

第二种方法确实发送了更多的字节,但这可能没有转换速度那么重要。

两者看起来也都非常快,但在处理数十万行或更多行的时候,速度可能会有所不同。

此外,是否可能有更好的方法来消除SQL中datetime的时间部分?


当前回答

CAST(round(cast(getdate()as real),0,1) AS datetime)

此方法不使用字符串函数。日期基本上是一种真实的数据类型,小数点前的数字是一天的小数。

我猜这个会比很多快。

其他回答

如何选择cast(cast my_datetime_field as date) as datetime)?结果是相同的日期,时间设置为00:00,但避免了任何文本转换,也避免了任何显式的数字舍入。

对我来说,下面的代码总是一个赢家:

SELECT CONVERT(DATETIME, FLOOR(CONVERT(FLOAT,GETDATE())));

在SQL Server 2008中,有一个DATE数据类型(也是一个TIME数据类型)。

CAST(GetDate() as DATE)

or

declare @Dt as DATE = GetDate()

我已经回答过了,但我也要把这个说出来…… 这应该也表现得很好,但它的工作原理是从浮点数中扔掉小数(存储时间),只返回整部分(即日期)

 CAST(
FLOOR( CAST( GETDATE() AS FLOAT ) )
AS DATETIME
)

我第二次找到这个解决方案…我把这个代码抄下来了

在这里,我做了一个函数来删除SQL Server的日期时间的某些部分。用法:

第一个参数是要剥离的datetime。 第二个参数是char类型: S:转到秒;删除毫秒 M:数到分钟;删除秒和毫秒 H:转到小时;删除分钟、秒和毫秒。 D:轮到天;删除小时、分钟、秒和毫秒。 返回新的日期时间

创建函数dbo。uf_RoundDateTime(@dt作为datetime, @part作为char) 返回日期时间 作为 开始 如果CHARINDEX(@part, 'smhd',0) = 0返回@dt; 返回演员( 案例@part 当's'时,convert(varchar(19), @dt, 126) 当'm'时,则convert(varchar(17), @dt, 126) + '00' 当'h'时,则convert(varchar(14), @dt, 126) + '00:00' 当'd'时,convert(varchar(14), @dt, 112) 结束为datetime) 结束