7

我正在调试一个会议室预订日历,该日历是由不再与我合作的人整理的。这是一场噩梦,因为它有很多问题,但我无法弄清楚究竟是什么导致了最后一个错误。日历会检查房间是否已经在特定时间被预订,并且他们没有显示在正确的时间预订的问题,但是如果有人在房间空出后一小时或更短的时间内尝试预订同一个房间移入或移出 DST,它显示房间仍被预订。例子:

  • 用户看到房间已为 11 月 29 日上午 9 点至 10 点预订。
  • 然后,用户尝试在 11 月 29 日上午 10:30 至下午 12:00 预订房间。
  • 日历取消第二个请求并通知用户房间已被预订。

应该注意的是,在转换为 DST(11 月 4 日)之前的任何时候都不会发生这种情况。这是确定房间是否可用的函数:

    function calCheck($starttime, $endtime, $cal_name, $cat_id, $myDB, $myHost, $myUser, $myPass) {
    $timezone = 'America/Denver';
    date_default_timezone_set ($timezone);
    $dset = new DateTime($odate, new DateTimeZone($timezone));
    $dset2 = $dset->getOffset();

    //$starttime = $starttime + 1;
    //$endtime = $endtime  - 1;     
    $starttime = $starttime - $dset2 + 1;
    $endtime = $endtime - $dset2 - 1;
    $starttime = $starttime;
    $endtime = $endtime; 

    //echo $starttime .'</br>'. $endtime . '</br>';
    $db = new myDB($myDB, $myHost, $myUser, $myPass);
    $db->myDB_Connect();
    //echo 'calcheck</br>';
    $ck_query = 'SELECT * FROM vw_cal_chk 
                    WHERE (stime < '. $starttime . '  AND etime > ' . $starttime . ' ) and Calendar = "' . $cal_name . '" and cat_id = "' .$cat_id . '"
                    OR (stime < ' . $endtime . ' AND etime > ' . $endtime . ') and Calendar = "' . $cal_name . '" and cat_id = "' .$cat_id . '"
                    OR (stime >= '. $starttime . ' AND etime < ' . $endtime .') and Calendar = "' . $cal_name . '" and cat_id = "' .$cat_id . '"';
    $ck_result = $db->myQuery($ck_query);
    $num = mysql_num_rows($ck_result);  
    //echo $ck_query . '</br>' . $num;
    if ($num >> 0){
        $avail = 1;
    } else {
        $avail = 0;
    }
    return $avail;
}

到目前为止,我所有的时间戳都是 UTC 格式,我注意到该$odate变量实际上从未在任何地方实例化,但我无法确定要传递什么值才能使偏移正常工作。如果我能找出它想要什么样的约会,我应该能够解决剩下的问题。

4

1 回答 1

1

$odate 为 null,默认为现在为您提供当前偏移量。您想要的是设置计划时的偏移量,而不是此时的偏移量。看起来您的数据库日期是山区时间,并且您的 startdate 是 utc 并且您正在减去偏移量以返回山区(我认为您会添加偏移量而不是减法,所以我可能会颠倒过来,您可以查询你的数据库并弄清楚?)

无论如何,您应该使用 $startdate 而不是 now() 来计算偏移量,尝试将 $startdate 切换为 $odate,看看会发生什么。如果这不起作用,请尝试从 startdate 构建一个字符串,然后从该字符串生成一个新日期。如果没有其他输出该字符串应该让您清楚地了解 $startdate 是 UTC 还是山区

于 2012-12-28T18:42:32.127 回答