1

我正在尝试将新行保存到报价中,但 Yii 不保存 QuoteRow。它只保存新服务(是的,数据库结构有点奇怪)。我似乎无法弄清楚。如果该行没有被保存, $qr->save() 应该返回 false 但它没有。服务已成功插入,但报价行没有。

$service = new Services;
$service->label = $row['title'] ?: "Övrigt";
$service->is_priced_per_unit = 1;
$service->price_per_unit = $row['price']*0.8;
$service->is_default = 0;
$service->rot_deductable = (int)isset($row['rot']);
$service->rot_deduction_percentage = 0.5;
if (!$service->save()) $this->addError('Kunde inte spara raden',$service->getErrors());
    else{
    $qr = new QuoteRows;
    $qr->quote_service_id = Yii::app()->db->getLastInsertID();
    $qr->quote_id = $id;
    $qr->unit_size = $row['amount'] ?: 0;
    $qr->raw_price = $row['price']*0.8*($row['amount'] ?: 1);
    $qr->is_rot_deductable = isset($row['rot']) ? 1 : 0;
    $qr->is_active = 1;

    if (!$qr->save()) $this->addError('Kunde inte spara raden',$qr->getErrors());
}

如果 $qr 没有保存,我应该得到错误。我还尝试使用 validate-function 来验证 $qr,它声称它是完全有效的!

4

5 回答 5

1

要么使用调试模式,要么在模型中使用带有 print_r($model) 的 beforeValidate、beforeSave 方法;

如果设置了所有属性,则应保存新数据;显然缺少一些东西。

于 2013-04-02T18:48:09.427 回答
1

我有同样的问题,但我忘记了 beforSave 方法。它返回 false 但我没有设置任何错误。所以 getErrors 方法的返回数组是空的。

于 2013-11-30T07:12:04.313 回答
1

确保你的 beforeSave、afterSave 函数返回 true

于 2014-11-05T02:49:21.680 回答
0

您在同一个控制器中使用两个模型。最好在“服务模型”中公开将“报价行”中的所有字段导入“服务”。在保存的同时使用 POST 方法获取值并通过 QuoteRows 模型保存。您也可以在“服务模型”中添加验证条件。

于 2015-01-31T07:56:50.703 回答
0

您可能在模型中使用了一个不返回 true 的事件。例如。public function beforeSave() {....... return true;//must return true after everything}

于 2017-06-16T16:19:09.663 回答