数据未被cron作业更新

时间:2012-09-11 13:40:36

标签: php pdo cron

我正在使用cron作业从事务表中获取总计并更新另一个表。 在我的cron作业电子邮件中,我回来说任务已完成,但没有看到我的数据发生变化。

    <?php

try {
    $dbh = new PDO("mysql:host=localhost;dbname=the", 'the', '1');
        $query = "UPDATE Test a 
                INNER JOIN
                (
                    SELECT ID, SUM(Total) as Total, 
                    FROM TestTrans
                    WHERE Status = ? 
                    Group By ID
                ) b
                ON a.ID = b.ID
        SET a.Total = b.Total
    Where a.Total > b.Total";

    $iStatus = 1;
    $stmt = $dbh->prepare($query);
    $stmt->bindParam(1, $iStatus);

    $stmt->execute();    

    echo 'Task Completed';
    }
    catch(PDOException $e)
    {
    echo $e->getMessage();
    }


    ?>

1 个答案:

答案 0 :(得分:1)

一些建议:

  • 以与cron相同的方式从命令提示符手动运行脚本。例如php myscript.php myoptions。它有用吗?
  • 在您的cron作业中添加一些日志记录:

* / 5 * * * * php myscript.php myoptions&gt;&gt; /var/log/cronrun.log 2&amp;&gt; 1

在/var/log/cronrun.log文件中查找错误和线索/