0

beforeDelete機能を持つ次のモデル Task があります。

public function beforeDelete()
{
    $model=Proposal::model()->findAllByAttributes(array('task_id'=>$this->id));
    $model->updateAll(array('task_id'=>null, 'task_result'=>null));
    parent::beforeDelete();
}

Proposalご覧のとおり、 (フィールドを使用して) モデルからいくつかのレコードを取得task_idし、並べ替えられたレコードのいくつかのフィールドを更新したいと思います。しかし、このコードは機能しません。タスクは、提案テーブルのフィールドを更新せずにタスク テーブルから削除されます。どうすれば修正できますか?

更新しました:

$model=Proposal::model()->findAllByAttributes(array('task_id'=>$this->id));
foreach ($model as $proposal)
{
    $proposal->task_id=null;
    $proposal->task_result=null;
    $proposal->update();
}
parent::beforeDelete();

コードを更新したばかりですが、まだ機能しません。

4

2 に答える 2

2

単に試してください(使用する必要はありませんfindAllByAttributes):

Proposal::model()->updateAll(
    array('task_id'=>null, 'task_result'=>null),
    'task_id=:task_id',
    array(':task_id'=>$this->id)
);
return parent::beforeDelete();

DCoderがコメントで述べたように、これが最良の選択肢です。

そして、ケビン・ヒギンズがその答えで言ったように、あなたは戻ってくるべきparent::beforeDelete()です.

http://www.yiiframework.com/doc/api/1.1/CActiveRecord#updateAll-detail

または、まだ使用したい場合findAllByAttributes

$models = Proposal::model()->findAllByAttributes(array('task_id'=>$this->id));
foreach ($models as $proposal)
{
    $proposal->update(array('task_id'=>null, 'task_result'=>null));
}
return parent::beforeDelete();

http://www.yiiframework.com/doc/api/1.1/CActiveRecord#update-detail

または:

$models = Proposal::model()->findAllByAttributes(array('task_id'=>$this->id));
foreach ($models as $proposal)
{
    $proposal->task_id=null;
    $proposal->task_result=null;
    $proposal->save();
}
return parent::beforeDelete();

http://www.yiiframework.com/doc/api/1.1/CActiveRecord#save-detail

于 2013-05-10T16:32:39.577 に答える
1

元の削除コードが間違っていることに加えて、parent::beforeDelete(); の結果を返す必要があります。

コードは次のようになります (soju の 3 番目の推奨事項を使用)。

public function beforeDelete()
{
    Proposal::model()->updateAll(
        array('task_id'=>null, 'task_result'=>null),
        'task_id=:task_id',
        array(':task_id'=>$this->id)
    );
    return parent::beforeDelete();
}
于 2013-05-10T19:53:31.267 に答える