>백엔드 개발 >PHP 튜토리얼 >MySQL 날짜/시간 필드에서 일광 절약 시간을 처리하는 방법은 무엇입니까?

MySQL 날짜/시간 필드에서 일광 절약 시간을 처리하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-16 19:39:03801검색

How to Handle Daylight Savings Time in MySQL Datetime Fields?

MySQL 날짜/시간 필드에서 일광 절약 시간 처리

MySQL에서 날짜/시간 필드를 사용할 때 시간대 오프셋을 지정하는 것은 특히 문제가 될 수 있습니다. 일광 절약 시간제(DST)를 처리할 때.

MySQL의 날짜/시간 필드는 타임스탬프를 저장합니다. 시간대 변환을 적용하지 않고 직접적으로. 이는 DST를 준수하는 시간대에 저장될 때 타임스탬프가 모호할 수 있음을 의미합니다. 예를 들어, "2009-11-01 01:30:00"은 가을 "폴백" 전후의 01:30:00을 나타낼 수 있습니다.

DST 전환 중에 시간 데이터를 정확하게 저장하고 검색하려면 , 다음 단계를 권장합니다.

  1. DATETIME 사용 필드:

    • TIMESTAMP 필드는 자동으로 타임스탬프를 UTC로 변환하고 그 반대로 변환하므로 DST와 함께 시간대를 사용할 때 왕복 손실이 발생할 수 있습니다.
    • 반면에 DATETIME 필드는 저장합니다. 타임스탬프 있는 그대로.
  2. 저장하기 전에 시간대 변환:

    • 정확한 저장을 보장하려면 시스템 시간대에서 타임스탬프를 변환하세요. DST가 아닌 시간대(예: UTC)로 저장한 후 데이터베이스.
  3. 검색 전 시간대 변환:

    • 검색된 타임스탬프를 정확하게 해석하려면 UTC 시간대에서 다시 변환하세요. MySQL 외부의 외부 함수(예: PHP의 strtotime() 또는 DateTime 클래스).
  4. MySQL 날짜/시간 수학 함수 피하기:

    • MySQL의 날짜/시간 수학 함수는 오작동할 수 있습니다. DST에 저장된 타임스탬프를 처리할 때 DST 경계 주변

이러한 단계를 따르면 DST 전환을 처리할 때에도 MySQL에서 시간 데이터를 안정적으로 저장하고 검색할 수 있으므로 타임스탬프가 정확하게 기록되고 표시됩니다.

위 내용은 MySQL 날짜/시간 필드에서 일광 절약 시간을 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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