집 >데이터 베이스 >MySQL 튜토리얼 >SQL의 GROUP BY를 사용하여 시간 간격(예: 10초, 30초)을 어떻게 분할할 수 있나요?
SELECT / GROUP BY - 분할 시간 간격(10초, 30초 등)
다음 기간 동안 데이터 집계 요청을 해결하려면 시계열 테이블 내에서 사용자 정의 시간 범위를 지정하려면 GROUP BY 절을 활용할 수 있습니다. 그러나 표준 그룹화 메커니즘은 원하는 세그먼트와 일치하지 않을 수 있습니다.
데이터를 10초 또는 30초 간격으로 그룹화하려면 UNIX_TIMESTAMP 함수를 활용하여 타임스탬프를 숫자 표현으로 변환한 다음 다음을 사용할 수 있습니다. DIV 연산자. 예를 들어 30초 간격으로 그룹화하려면:
GROUP BY UNIX_TIMESTAMP(time_stamp) DIV 30
마찬가지로 20초 간격으로 그룹화하려면:
GROUP BY UNIX_TIMESTAMP(time_stamp) DIV 20
세그먼트 경계를 조정하려면 다음 공식을 사용할 수 있습니다.
GROUP BY (UNIX_TIMESTAMP(time_stamp) + r) DIV 30
여기서 'r'은 30보다 작은 음이 아닌 정수를 나타냅니다. 예를 들어, 그룹화하려면 15초 간격으로:
GROUP BY (UNIX_TIMESTAMP(time_stamp) + 5) DIV 30
이렇게 하면 hh:mm:05에서 hh:mm:35까지, 그리고 hh:mm:35에서 hh:mm 1:05까지 세그먼트가 생성됩니다. 이러한 기술을 활용하면 사용자 정의된 시간 간격에 걸쳐 데이터를 효과적으로 집계할 수 있어 세부적인 분석 및 데이터 요약이 가능합니다.
위 내용은 SQL의 GROUP BY를 사용하여 시간 간격(예: 10초, 30초)을 어떻게 분할할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!