>데이터 베이스 >MySQL 튜토리얼 >MySQL의 CONVERT_TZ() 함수는 일광 절약 시간을 어떻게 처리합니까?

MySQL의 CONVERT_TZ() 함수는 일광 절약 시간을 어떻게 처리합니까?

DDD
DDD원래의
2024-11-28 14:33:11947검색

How Does MySQL's CONVERT_TZ() Function Handle Daylight Saving Time?

일광 절약 시간을 적용한 MySQL CONVERT_TZ()

사용자 정의 현지 시간대로 지정된 데이터베이스에 일일 알림을 저장할 때, 일광 절약 시간(DST)을 고려하는 것이 중요합니다. 이 문서에서는 DST를 수용하기 위한 CONVERT_TZ() 함수의 사용 방법을 살펴보고 구현과 관련된 일반적인 질문에 대해 설명합니다.

질문 1: DST를 사용한 시간대 변환

CONVERT_TZ() 함수는 시간대 이름을 지정할 때 DST를 고려합니다. 예를 들어 UTC 시간을 미국/동부 시간으로 변환하면 DST 적용 여부에 따라 결과가 달라집니다. 이는 CONVERT_TZ('00:00:00', 'UTC', 'US/EASTERN')이 1월 1일에 '19:00:00'을 반환하고 7월 1일에 '20:00:00'을 반환해야 한다는 사용자의 이해와 일치합니다.

질문 2: MySQL 시간대 테이블 업데이트

CONVERT_TZ() 함수가 올바르게 작동하는 경우 일반적으로 MySQL의 시간대 테이블을 수동으로 업데이트할 필요가 없습니다. MySQL은 시간대 정보를 저장하고 시간대 규정의 변경에 따라 필요에 따라 이를 업데이트하는 내부 데이터베이스를 유지 관리합니다. 그러나 시간대 설정을 사용자 정의한 경우 정기적으로 표를 검토하여 정확성을 확인하는 것이 좋습니다.

질문 3: CONVERT_TZ()의 Null 값

CONVERT_TZ()가 NULL을 반환하는 경우 이는 MySQL 시간대 테이블이 제대로 설정되지 않았음을 나타냅니다. 다음 쿼리를 실행하여 이를 확인할 수 있습니다.

SELECT CONVERT_TZ(now(), 'US/Eastern', 'US/Central');

이 쿼리가 NULL을 반환하면 테이블이 구성되지 않은 것입니다. 이 문제를 해결하려면 MySQL 설명서에서 시간대 테이블 설정에 대한 지침을 참조하세요.

대체 접근 방식

MySQL 시간대 테이블에서는 다음 접근 방식을 사용할 수 있습니다.

  1. UTC로부터의 사용자 시간대 오프셋을 시간 단위로 저장합니다. 별도의 테이블.
  2. utc_timezone() 함수를 사용하여 현재 UTC 시간을 가져옵니다.
  3. 시간대 오프셋을 빼서 사용자의 현지 시간을 계산합니다.

의 경우 예:

SELECT utc_timezone() - interval user_timezone_offset_in_hours hour
FROM userinfo a
WHERE user_id = 999;

위 내용은 MySQL의 CONVERT_TZ() 함수는 일광 절약 시간을 어떻게 처리합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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