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