SQL: Data Transpose

I have a SQL script that outputs this:

timestamp tagname value
12/19/2024 15:00:57 RUNNING 0
12/19/2024 15:00:55 RUNNING 1
12/19/2024 14:53:38 RUNNING 0
12/19/2024 14:53:35 RUNNING 1
12/19/2024 14:53:08 RUNNING 0
12/19/2024 14:53:03 RUNNING 1

The script needs to take this data, evaluate when the value is 1 then capture the timestamp as StartTime and when the value is 0 capture the timestamp as EndTime. Further I need to query a table that has RunID associated with the StartTime and use that for the RunID. The RunID is set by a user unique (assume that the RunID is unique) , its set when the Running tag goes to 1 in the machine.

RunID Timestamp
XYZ123 12/19/2024 15:00:55
XYZ980 12/19/2024 14:53:35
XYZ456 12/19/2024 14:53:03

The final output should be:

RunID StartTime Endtime
XYZ456 12/19/2024 14:53:03 12/19/2024 14:53:08
XYZ980 12/19/2024 14:53:35 12/19/2024 14:53:38
XYZ123 12/19/2024 15:00:55 12/19/2024 15:00:57

9

Assuming that the start timestamp is always identical to the run timestamp, matching the run to the start is a simple join. To find the EndTime, you can use the CROSS APPLY(SELECT TOP 1 ... ORDER BY ...) pattern to locate the next end time following the start.

SELECT R.RunID, S.Timestamp AS StartTime, E.Timestamp AS EndTime
FROM Run R
JOIN TagHistory S
    ON S.timestamp = R.Timestamp
    AND S.Tagname = 'RUNNING'
    AND S.Value = 1
CROSS APPLY (
    SELECT TOP 1 *
    FROM TagHistory E
    WHERE E.timestamp >= S.Timestamp
    AND E.Tagname = 'RUNNING'
    AND E.Value = 0
    ORDER BY E.Timestamp
) E
ORDER BY R.Timestamp

Since you don’t really pull any other data from the start time row, that join can actually be eliminated.

SELECT R.RunID, R.Timestamp AS [StartTime(RunTime)], E.Timestamp AS EndTime
FROM Run R
CROSS APPLY (
    SELECT TOP 1 *
    FROM TagHistory E
    WHERE E.timestamp >= R.Timestamp
    AND E.Tagname = 'RUNNING'
    AND E.Value = 0
    ORDER BY E.Timestamp
) E
ORDER BY R.Timestamp

However, if there is a chance that the start time can be slightly later than the run timestamp (possible with two separate inserts each with its own GETDATE() reference), it would be more reliable to use the CROSS APPLY technique to retrieve both the start and end timestamp rows.

Also, if there is a chance that one or both history rows might be missing (perhaps a job is still running), changing the CROSS APPLY to an OUTER APPLY will still yield a result rows (similar to a LEFT JOIN.

SELECT
    R.RunID, R.Timestamp as RunIdTime,
    S.Timestamp AS StartTime, E.Timestamp AS EndTime
FROM Run R
OUTER APPLY (
    SELECT TOP 1 *
    FROM TagHistory S
    WHERE S.timestamp >= R.Timestamp
    AND S.Tagname = 'RUNNING'
    AND S.Value = 1
    ORDER BY S.Timestamp
) S
OUTER APPLY (
    SELECT TOP 1 *
    FROM TagHistory E
    WHERE E.timestamp >= S.Timestamp
    AND E.Tagname = 'RUNNING'
    AND E.Value = 0
    ORDER BY E.Timestamp
) E
ORDER BY R.Timestamp

The above queries assume that the timestamp values do not have ambiguities, such as duplicate run timestamps, overlapping runs, or one run’s end timestamp equaling the next run’s start time.

Sample results (with some extra data):

RunID RunIdTime StartTime EndTime
XYZ456 2024-12-19 14:53:03 2024-12-19 14:53:03 2024-12-19 14:53:08
XYZ980 2024-12-19 14:53:35 2024-12-19 14:53:35 2024-12-19 14:53:38
XYZ123 2024-12-19 15:00:55 2024-12-19 15:00:55 2024-12-19 15:00:57
ZZZ111 2024-12-20 01:02:03 2024-12-20 01:02:04 2024-12-20 01:02:05
ZZZ222 2024-12-20 11:12:13 2024-12-20 11:22:14 null

See this db<>fiddle for a demo.

Trang chủ Giới thiệu Sinh nhật bé trai Sinh nhật bé gái Tổ chức sự kiện Biểu diễn giải trí Dịch vụ khác Trang trí tiệc cưới Tổ chức khai trương Tư vấn dịch vụ Thư viện ảnh Tin tức - sự kiện Liên hệ Chú hề sinh nhật Trang trí YEAR END PARTY công ty Trang trí tất niên cuối năm Trang trí tất niên xu hướng mới nhất Trang trí sinh nhật bé trai Hải Đăng Trang trí sinh nhật bé Khánh Vân Trang trí sinh nhật Bích Ngân Trang trí sinh nhật bé Thanh Trang Thuê ông già Noel phát quà Biểu diễn xiếc khỉ Xiếc quay đĩa Dịch vụ tổ chức sự kiện 5 sao Thông tin về chúng tôi Dịch vụ sinh nhật bé trai Dịch vụ sinh nhật bé gái Sự kiện trọn gói Các tiết mục giải trí Dịch vụ bổ trợ Tiệc cưới sang trọng Dịch vụ khai trương Tư vấn tổ chức sự kiện Hình ảnh sự kiện Cập nhật tin tức Liên hệ ngay Thuê chú hề chuyên nghiệp Tiệc tất niên cho công ty Trang trí tiệc cuối năm Tiệc tất niên độc đáo Sinh nhật bé Hải Đăng Sinh nhật đáng yêu bé Khánh Vân Sinh nhật sang trọng Bích Ngân Tiệc sinh nhật bé Thanh Trang Dịch vụ ông già Noel Xiếc thú vui nhộn Biểu diễn xiếc quay đĩa Dịch vụ tổ chức tiệc uy tín Khám phá dịch vụ của chúng tôi Tiệc sinh nhật cho bé trai Trang trí tiệc cho bé gái Gói sự kiện chuyên nghiệp Chương trình giải trí hấp dẫn Dịch vụ hỗ trợ sự kiện Trang trí tiệc cưới đẹp Khởi đầu thành công với khai trương Chuyên gia tư vấn sự kiện Xem ảnh các sự kiện đẹp Tin mới về sự kiện Kết nối với đội ngũ chuyên gia Chú hề vui nhộn cho tiệc sinh nhật Ý tưởng tiệc cuối năm Tất niên độc đáo Trang trí tiệc hiện đại Tổ chức sinh nhật cho Hải Đăng Sinh nhật độc quyền Khánh Vân Phong cách tiệc Bích Ngân Trang trí tiệc bé Thanh Trang Thuê dịch vụ ông già Noel chuyên nghiệp Xem xiếc khỉ đặc sắc Xiếc quay đĩa thú vị
Trang chủ Giới thiệu Sinh nhật bé trai Sinh nhật bé gái Tổ chức sự kiện Biểu diễn giải trí Dịch vụ khác Trang trí tiệc cưới Tổ chức khai trương Tư vấn dịch vụ Thư viện ảnh Tin tức - sự kiện Liên hệ Chú hề sinh nhật Trang trí YEAR END PARTY công ty Trang trí tất niên cuối năm Trang trí tất niên xu hướng mới nhất Trang trí sinh nhật bé trai Hải Đăng Trang trí sinh nhật bé Khánh Vân Trang trí sinh nhật Bích Ngân Trang trí sinh nhật bé Thanh Trang Thuê ông già Noel phát quà Biểu diễn xiếc khỉ Xiếc quay đĩa
Thiết kế website Thiết kế website Thiết kế website Cách kháng tài khoản quảng cáo Mua bán Fanpage Facebook Dịch vụ SEO Tổ chức sinh nhật