>데이터 베이스 >MySQL 튜토리얼 >SQL의 GROUP BY를 사용하여 시간 간격(예: 10초, 30초)을 어떻게 분할할 수 있나요?

SQL의 GROUP BY를 사용하여 시간 간격(예: 10초, 30초)을 어떻게 분할할 수 있나요?

DDD
DDD원래의
2025-01-05 02:05:40936검색

How Can I Segment Time Intervals (e.g., 10 Seconds, 30 Seconds) Using SQL's GROUP BY?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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