如果有人有想法,请寻求有关奇怪问题的帮助:
我有一个 SQL,该语句大部分时间都在 T-SQL 脚本中工作,但偶尔会崩溃。我已经确定了发生崩溃的数据,并且无法确定有效的数据行之间的任何差异。
此代码的目标是将时间添加到已经存在的日期时间值,该值具有 00:00:00 作为第二个时间列的时间(如下所述)。我的目标是将两列合并为 YYYY-MM-DD HH:MM:SS 格式,但我必须先将它们转换为 char 以修剪掉原来的 00:00:00。
列
LogDate - 仅包含 DateTime 格式的日期 (YYYY-MM-DD HH:MM:SS)
LogTime - 包含操作的时间,采用 varchar 格式 (HH:MM)
SQL 转换
SELECT CONVERT(DATETIME, CONVERT(CHAR(8), LogDate, 112) + ' ' + CONVERT(CHAR(8), LogTime, 108))
FROM TestTable
WHERE EventSerial = '100001'
但是,如果我将上述语句中的 EventSerial 更改为不同的行,例如“100002”,则该语句有效。
每一行的数据如下:
EventSerial 100001 的值: LogDate:2015-04-02 00:00:00.000 LogTime:10:04
EventSerial 100002 的值: LogDate:2015-04-02 00:00:00.000 LogTime:10:48
使用数据集 1 运行失败,使用数据集 2 运行会产生输出。此外,在没有最终日期时间转换的情况下运行代码,或者如果我手动运行带有字符串的代码,它可以工作(如下所述:)
SELECT CONVERT(CHAR(8), LogDate, 112) + ' ' + CONVERT(CHAR(8), LogTime, 108)
FROM TestTable
WHERE EventSerial = '100001'
SELECT CONVERT(DATETIME, '20150402 10:48')
SELECT CONVERT(DATETIME, '20150402 10:04')
任何建议,我确信我错过了一些愚蠢的东西(无论如何我可能花了很长时间解决这个问题。所需的输出将是 2015-04-02 10:04:00