Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/60.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql Zend_Date和Cronjob的反常行为_Mysql_Zend Framework_Date_Datetime - Fatal编程技术网

Mysql Zend_Date和Cronjob的反常行为

Mysql Zend_Date和Cronjob的反常行为,mysql,zend-framework,date,datetime,Mysql,Zend Framework,Date,Datetime,我们有一个Cron脚本,它可以检测一些用户是否被踢出我们的应用程序。 如果特定值为1,我们可以检测到这一点,但是在流中,没有设置新条目。 脚本每小时运行一次。大部分未被检测到。但自2012年10月31日23:59:03起,每个用户都被检测到。如果我在本地maschine上运行脚本,或者甚至在cron运行的同一台机器上运行脚本。一切都得到了应有的处理。 首先,我们的剧本: require_once ('cron_init.php'); ini_set('date.timezone', 'Europ

我们有一个Cron脚本,它可以检测一些用户是否被踢出我们的应用程序。 如果特定值为1,我们可以检测到这一点,但是在流中,没有设置新条目。 脚本每小时运行一次。大部分未被检测到。但自2012年10月31日23:59:03起,每个用户都被检测到。如果我在本地maschine上运行脚本,或者甚至在cron运行的同一台机器上运行脚本。一切都得到了应有的处理。 首先,我们的剧本:

require_once ('cron_init.php');
ini_set('date.timezone', 'Europe/Berlin');
ini_set('max_execution_time', 30);
ini_set('memory_limit', -1);
error_reporting(E_ALL);
ini_set("display_errors", 1);

Zend_Date::setOptions(array('fix_dst' => true));

    $userinfos = new Repricing_Dbservices_Userinfos();
    $users = $userinfos->getUsersForRepricing();

    $repricingstream = new Repricing_Dbservices_Repricingstream();
    $error = new Repricing_Dbservices_Error();

if($users!==false AND count($users)>0){

    $counter = 0;
    $errCounter = 0;
    $jetzt = new Zend_Date();
    $jetzt->setTimezone('Europe/Berlin');
    $jetzt = $jetzt->get(Zend_Date::TIMESTAMP);

    foreach($users as $user){
        $stream = $repricingstream->getStreamLimit($user);

        $last = new Zend_Date($stream);
        $last->setTimezone('Europe/Berlin');
        $last = $last->get(Zend_Date::TIMESTAMP);

        $diff = (($jetzt-$last)/60);

        $error->setError(1, 'DIED', $diff, $user);

        if($diff > 50 ){
            $errCounter++;
            $userinfos->setUserFree($user);
            $error->setError(1, 'DIED', 'ANSTOSSEN', $user);
        }

        $counter++;
    }
    $error->setError(1, $errCounter, 'ANSTOSSEN_ALL', 'ALL');
}
通常,
$diff>=0和$diff考虑以下情况:

$right = new Zend_Date('2012-11-01 12:12:12', Zend_Date::ISO_8601);
var_dump( $right->getIso() );        // 2012-11-01T12:12:12+00:00
var_dump( $right->getTimestamp() );  // 1351771932

$wrong = new Zend_Date('2012-11-01 12:12:12', null, 'en_US');
var_dump( $wrong->getIso() );        // 2012-01-11T12:12:12+00:00
var_dump( $wrong->getTimestamp() );  // 1326283932
现在,真正奇怪的部分是:在我的电脑上,这是第二个默认行为——即,当Zend_Date构造函数没有额外的参数时

关键是,Zend_Date有点。。。在尝试分析日期时间字符串时太有用了。例如,它考虑了语言环境,但同时考虑了服务器和客户端的语言环境!如果字符串不能在该语言环境的规则中解析,它会自动放弃,并尝试使用另一个规则

这就是为什么
2012-10-29
被解析为
10月29日
(不管语言环境如何建议,因为没有第29个月)-但是
2012-11-01
变成了
1月11日
-并且把你的脚本搞砸了。)

考虑一下:

$right = new Zend_Date('2012-11-01 12:12:12', Zend_Date::ISO_8601);
var_dump( $right->getIso() );        // 2012-11-01T12:12:12+00:00
var_dump( $right->getTimestamp() );  // 1351771932

$wrong = new Zend_Date('2012-11-01 12:12:12', null, 'en_US');
var_dump( $wrong->getIso() );        // 2012-01-11T12:12:12+00:00
var_dump( $wrong->getTimestamp() );  // 1326283932
现在,真正奇怪的部分是:在我的电脑上,这是第二个默认行为——即,当Zend_Date构造函数没有额外的参数时

关键是,Zend_Date有点。。。在尝试分析日期时间字符串时太有用了。例如,它考虑了语言环境,但同时考虑了服务器和客户端的语言环境!如果字符串不能在该语言环境的规则中解析,它会自动放弃,并尝试使用另一个规则


这就是为什么
2012-10-29
被解析为
10月29日
(不管语言环境如何建议,因为没有第29个月)-但是
2012-11-01
变成了
1月11日
-并且把你的脚本搞砸了。)

什么是
getStreamLimit
return(我的意思是,你能举一些例子吗?)是的,当然
getStreamLimit()
返回在数据库中写入的特定用户的最后日期时间操作。例如:2012-11-02 16:50:03I此处嗅到日期格式不兼容-换句话说,此行的解析方式类似于“YYYY-DD-MM”,而不是“YYYY-MM-DD”。你能在
新日期
调用中设置格式吗?好的,我更新了
$last=new Zend_Date($stream,'YYYY-MM-DD HH:MM:ss')在20分钟内我发布了发生的事情。什么是
getStreamLimit
return(我的意思是,你能举一些例子吗?)是的,当然
getStreamLimit()
返回在数据库中写入的特定用户的最后日期时间操作。例如:2012-11-02 16:50:03I此处嗅到日期格式不兼容-换句话说,此行的解析方式类似于“YYYY-DD-MM”,而不是“YYYY-MM-DD”。你能在
新日期
调用中设置格式吗?好的,我更新了
$last=new Zend_Date($stream,'YYYY-MM-DD HH:MM:ss')20分钟后我发布了发生的事情。是的,你完全正确,用它。你的提示解决了我的问题。非常感谢。你也给出了一个事实,为什么会在那个特定的日期发生。好的;)是的,你说得完全对,没错。你的提示解决了我的问题。非常感谢。你也给出了一个事实,为什么会在那个特定的日期发生。好的;)