>데이터 베이스 >MySQL 튜토리얼 >테이블의 연속 레코드 간의 시간 차이를 계산하는 방법은 무엇입니까?

테이블의 연속 레코드 간의 시간 차이를 계산하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-19 16:10:03727검색

How to Calculate Time Difference Between Consecutive Records in a Table?

연속 레코드 간의 시간 차이 계산

이 작업은 StartDate 열이 있는 테이블에서 인접한 행 간의 시간 차이를 확인하는 것입니다. 테이블 구조가 주어지면 연속 행의 각 쌍 사이의 시간적 간격을 계산해야 합니다.

한 가지 접근 방식은 MyTable에 대한 자체 조인을 포함합니다. 다음 쿼리는 이를 달성합니다.

SELECT A.requestid, A.starttime, (B.starttime - A.starttime) AS timedifference
FROM MyTable A INNER JOIN MyTable B ON B.requestid = (A.requestid + 1)
ORDER BY A.requestid ASC

이 방법은 연속 레코드 간의 시간 차이를 성공적으로 계산합니다. 그러나 요청 ID가 연속적이지 않은 경우 다음 쿼리를 사용할 수 있습니다.

SELECT A.requestid, A.starttime, (B.starttime - A.starttime) AS timedifference
FROM MyTable A CROSS JOIN MyTable B
WHERE B.requestid IN (SELECT MIN (C.requestid) FROM MyTable C WHERE C.requestid > A.requestid)
ORDER BY A.requestid ASC

CROSS JOIN과 하위 쿼리를 활용하여 이 접근 방식은 현재 요청 ID보다 큰 최소 요청 ID를 식별합니다. , 연속되지 않은 기록에 대해서도 시차 계산이 가능합니다.

위 내용은 테이블의 연속 레코드 간의 시간 차이를 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.