>데이터 베이스 >MySQL 튜토리얼 >`strtotime()`을 사용할 때 PHP에서 1970년 이전 날짜를 어떻게 처리할 수 있나요?

`strtotime()`을 사용할 때 PHP에서 1970년 이전 날짜를 어떻게 처리할 수 있나요?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-25 11:31:14483검색

How Can I Handle Dates Before 1970 in PHP When Using `strtotime()`?

strtotime()을 사용하여 1970년 이전 날짜로 작업

문제:

yyyy-mm-dd 형식으로 날짜를 저장하는 MySQL 데이터베이스의 텍스트 열입니다. 귀하의 PHP 코드는 strtotime()을 사용하여 날짜를 변환하지만 1970년 1월 1일 이후의 값만 구문 분석한다는 것을 발견했습니다. 많은 날짜가 이 제한 이전에 속하므로 데이터베이스 구조를 변경하지 않고 해결 방법이 있는지 궁금합니다.

해결책:

공식 PHP 문서에서는 날짜 범위 제한을 강조합니다. strtotime():

Fri, 13 Dec 1901 20:45:54 GMT to Tue, 19 Jan 2038 03:14:07 GMT

옵션 1: PHP 버전 및 운영 체제 업그레이드

가능하다면 PHP 버전 5.1.0 이상으로 업그레이드하세요. 확장된 날짜 범위를 지원하는 플랫폼에서.

옵션 2: PHP의 DateTime 활용 객체

strtotime() 범위를 벗어난 날짜에는 DateTime 객체를 사용하는 것이 좋습니다. 더 큰 유연성을 제공합니다.

절차적 접근 방식:

$date = date_create($row['value']);
if (!$date) {
    $e = date_get_last_errors();
    foreach ($e['errors'] as $error) {
        echo "$error\n";
    }
    exit(1);
}

echo date_format($date, "F j, Y");

OOP 접근 방식:

try {
    $date = new DateTime($row['value']);
} catch (Exception $e) {
    echo $e->getMessage();
    exit(1);
}

echo $date->format("F j, Y");

위 내용은 `strtotime()`을 사용할 때 PHP에서 1970년 이전 날짜를 어떻게 처리할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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