私は2つの DateTime を比較しています:
//Get the current DateTime
$date_now = new DateTime;
var_dump($date_now); // 2014-03-10 19:04:29
// I need to subtract 12 hours (I'm using $date_past to fetch $db_date in a request)
$date_past = $date_now->sub(new DateInterval("PT12H"));
// Get the DateTime from $db_date just fetched in database
$alert_date = new DateTime($db_date);
var_dump($alert_date); // 2014-03-10 17:04:00 in my test
// Get the difference
$diff = $alert_date->diff($date_now);
var_dump($diff->format("%H:%I:%S")); //09:59:31
したがって、09:59:31 と $diff->invert == 1 を取得します。これは、負の値であることを意味します。
私はこの問題を見ました:php datetime->diffは間違った時間数を計算しています(3が多すぎます)。同様の問題だと思いますが、->sub()を使い続けるための解決策が見つかりません。何か案は ?
TimeZone の問題である可能性があると思われる場合は、すべての DateTime を確認しましたが、すべての TimeZone が「Europe/Berlin」に設定されているため、ここから来たとは思いません。
ありがとうございました !