-2

我有 2 个历史标签数据。我做 openquery 以在表中获取这些数据。数据是这样的:

标签1:

timestamp1 string1

标签2:

timestamp2 string2

我想把它合并到一张表中

timestamp1 string1 string2

问题是 Timestamp1 和 Timestamp2 不匹配。我需要在表中将 string1 和 string2 放在一起。有没有办法解决这个问题?此外,时间戳的差异可能会因情况而异。(可以是 100ms 到 5sec)

例子:

标签 1 表:

   10/09/2018 22:05:00          "hello"

   10/09/2018 22:10:00          "heyhey"

标签2表:

  10/09/2018 22:05:28          "azeryy"

  10/09/2018 22:10:04          "qwerty"

结果表:

  10/09/2018 22:05:00          "hello"      "azeryy"

  10/09/2018 22:10:00          "heyhey"     "qwerty" 
4

1 回答 1

1

将来,如果您可以发布示例数据,将会很有帮助。由于您是新来的,所以我为您整理了这些内容,因此您可以看到一个示例。

declare @Tag1 table
(
    SomeDate datetime
    , SomeValue varchar(20)
)

insert @Tag1 values
('10/09/2018 22:05:00', 'hello')
, ('10/09/2018 22:10:00', 'heyhey')

declare @Tag2 table
(
    SomeDate datetime
    , SomeValue varchar(20)
)

insert @Tag2 values
('10/09/2018 22:05:28', 'azeryy')
, ('10/09/2018 22:10:04', 'qwerty')

现在我们可以专注于手头的任务,将它们非常松散地合并在一起。Row_Number 对此非常有帮助。您可以在此处阅读有关 ROW_NUMBER 的更多信息。https://docs.microsoft.com/en-us/sql/t-sql/functions/row-number-transact-sql?view=sql-server-2017

select t1.SomeDate
    , t1.SomeValue
    , t2.SomeValue
from
(
    select *
        , RowNum = ROW_NUMBER() over(order by SomeDate desc)
    from @Tag1
) t1
join
(
    select *
        , RowNum = ROW_NUMBER() over(order by SomeDate desc)
    from @Tag2
) t2 on t2.RowNum = t1.RowNum
order by t1.SomeDate
于 2018-09-10T20:32:00.833 回答