PHP와 MySQL의 시간대
시간대 시스템 통합은 복잡할 수 있으며 PHP와 MySQL의 시간대를 이해하는 것은 어려울 수 있습니다. . 다음은 이 주제를 효과적으로 탐색하는 데 도움이 되는 포괄적인 가이드입니다.
데이터베이스에 시간대 저장
MySQL에 날짜를 저장할 때 항상 TIMESTAMP가 아닌 DATETIME을 사용하세요. DATETIME을 사용하면 더욱 세분화되고 유연해집니다. 모든 PHP 타임스탬프를 MySQL에 저장하기 전에 UTC로 변환하세요. 다음과 같은 코드를 사용할 수 있습니다.
$dateUTC = new DateTime('2023-03-08 14:30:00', new DateTimeZone('UTC'));
데이터베이스에서 시간대 검색
다음 코드를 사용하여 MySQL에서 날짜/시간을 검색할 수 있습니다.
$dateRetrieved = new DateTime($row['datetime_column'], new DateTimeZone('UTC'));
시간 변환 구역
검색된 날짜 시간을 표시된 사용자의 현지 시간대로 변환합니다. 이 작업은 다음을 사용하여 수행할 수 있습니다.
$localTime = $dateRetrieved->setTimeZone(new DateTimeZone('America/Los_Angeles'));
자동 일광 절약 시간(DST) 조정
강력한 기능을 위해 DateTime과 함께 DateTimeZone을 사용하세요. 최신 PHP 버전에는 사용자가 선택한 위치에 따라 DST를 자동으로 조정하는 데 사용할 수 있는 DateTimeZone 클래스가 포함되어 있습니다.
// This will be PDT right now, UTC-7 $la = new DateTimeZone('America/Los_Angeles'); $nowish->setTimeZone($la);
더 이상 사용되지 않는 시간대 방지
사용 Etc/GMT... 시간대 대신 명명된 시간대. 명명된 시간대가 바람직하며 향후 PHP 버전에서는 더 이상 사용되지 않습니다.
레거시 데이터 처리
시간대 없이 저장된 레거시 데이터 처리:
결론
PHP 및 MySQL의 시간대를 이해하려면 데이터 저장에 세심한 주의가 필요합니다. , 검색 및 변환. 여기에 설명된 지침을 따르면 PHP/MySQL 애플리케이션에서 사용자별 시간대를 정확하게 처리할 수 있습니다.
위 내용은 PHP 및 MySQL 애플리케이션에서 시간대를 효과적으로 관리하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!