집 >데이터 베이스 >MySQL 튜토리얼 >테이블의 연속 레코드 간의 시간 차이를 계산하는 방법은 무엇입니까?
연속 레코드 간의 시간 차이 계산
이 작업은 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!