我试图将新行保存到报价中,但Yii不保存QuoteRow。它只保存新的服务(是的,DB结构有点奇怪)。我似乎无法弄清楚。如果该行没有保存,$ qr-> save()应该返回false,但不会。该服务成功插入,但quoterow不是。新记录没有保存,也没有错误信息
$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没有保存,我应该得到错误。我也尝试使用验证函数验证$ qr,并声明它非常有效!
仅仅因为它通过Yii的验证并不意味着插入时没有mysql错误。你有没有检查你的错误日志?您是否启用了调试模式? – Pitchinnate
Pitchinnate - 是否意味着save()会隐藏一个SQL错误? – grantwparks