在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的时间部分?
在这里,我做了一个函数来删除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)
结束