1

如果有人有想法,请寻求有关奇怪问题的帮助:

我有一个 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

4

2 回答 2

0

首先,日期时间没有格式。(为什么?

其次,您不需要将datetime值转换char为添加小时和分钟,只需使用DateAdd

SELECT DATEADD(Minute, 
               CAST(RIGHT(LogTime, 2) as int), 
               DATEADD(Hour, 
                       CAST(LEFT(LogTime, 2) as int), 
                       LogDate
                   )
              )
FROM  TestTable
WHERE EventSerial = '100001'

另外,请注意,convert它不适合yyyymmdd hh:mm

注意:这里直接写代码,可能会有一些错误。

于 2015-06-03T18:21:18.377 回答
0

我不确定您为什么会收到错误消息...可能在您的 varchar 时间字段中存在一些看不见的字符...例如选项卡或其他什么?试试这个查询:

SELECT ascii(substring(LogTime,1,1)) Char1, 
    ascii(substring(LogTime,2,1)) Char2,  
    ascii(substring(LogTime,3,1)) Char3,  
    ascii(substring(LogTime,4,1)) Char4,  
    ascii(substring(LogTime,5,1)) Char5
FROM  TestTable
WHERE EventSerial = '100001'

它应该显示以下结果:

Char1       Char2       Char3       Char4       Char5
----------- ----------- ----------- ----------- -----------
49          48          58          48          52

(1 row(s) affected)

这会更有效率:

select dateadd(minute, datediff(minute,0, LogTime), LogDate)
FROM  TestTable

但这假设您的日期字段始终具有 00:00:00 时间信息。如果您想确保也将其剥离,您可以使用:

select dateadd(minute, datediff(minute,0, LogTime), dateadd(day, datediff(day, 0, Logdate),0))
FROM  TestTable
于 2015-06-03T18:43:28.623 回答