将Yii控制器操作移动到cron作业

时间:2013-01-20 21:12:27

标签: php mysql yii cron

我使用此site作为在yii中设置cron作业的指南。

当我将给定值(Value2)从“A”更改为“B”时,TableA(更新)中的当前控制器操作将执行sql事务以填充我的数据库中的TableB。

这是我目前用来完成此任务的代码。这是我在控制器A中的更新操作

$connection = yii::app()->db;
$sql1 = "INSERT INTO TableB (value1, value2, value3)
     VALUES(:val1, :val2, :val3)";
$command=$connection->createCommand($sql1);
$command->bindValue(":val1", $model->tableAId);
$command->bindValue(":val2", 'B');
$command->bindValue(":val3", $model->Attribute2);
$command->execute();

由于我使用的是bindValue,因此很容易将我的值输入到不同的表中。将此逻辑移到cron作业中我不知道从哪里开始执行相同的操作。

因此在cron作业中使用类似的代码也可以这样做吗?

public function run($args)
{
    $transactions = TableA::model()
    ->findBySql('SELECT * FROM `TableA` '.
    'WHERE `value2` = A '.
    'AND TO_DAYS(`DateCreated`)+3 < TO_DAYS(NOW())');
    foreach ($transactions as $transaction) {
        $connection = yii::app()->db;
        $sql1 = "INSERT INTO tableB (value1, value2, value3)
             VALUES(:val1, :val2, :val3)";
        $command=$connection->createCommand($sql1);
        $command->bindValue(":val1", $model->tableAId);
        $command->bindValue(":val2", 'B');
        $command->bindValue(":val3", $model->Attribute2);
        $command->execute();
    }
}

我需要在TableB中创建一条新记录,还要将TableA中的value2从“A”更新为“B”

我已经尝试过运行此cron作业,但没有得到任何结果,也不确定如何对其进行故障排除。

1 个答案:

答案 0 :(得分:0)

您可以使用TableA和TableB模型吗?

控制器A中的

$model = $this->loadModel();
$model->value2 = 'B';
if ($model->save()) {
   $modelB = new TableB();
   $modelB->value1 = $model->value1;
   $modelB->value2 = $model->value2;
   $modelB->value3 = $model->value3;
   $modelB->save();
}

在cron工作中

// find all
$transactions = TableA::model()->findAll(array('condition' => array(
  'value2 = :A',
  new CDbExpression('TO_DAYS(`DateCreated`)+3 < TO_DAYS(NOW())'),
), 'params' => array( ':A' => 'A')));
foreach ($transactions as $transaction) {
    $model->value2 = 'B';
    if ($model->save()) {
        $modelB = new TableB();
        $modelB->value1 = $model->value1;
        $modelB->value2 = $model->value2;
        $modelB->value3 = $model->value3;
        $modelB->save();
    }
}

或者您也可以在modelA中创建函数:

public function createB()
{
    $modelB = new TableB();
    $modelB->value1 = $model->value1;
    $modelB->value2 = $model->value2;
    $modelB->value3 = $model->value3;
    $modelB->save();
}

在需要时调用它