我有什么:
发票和 Invoiceitems 模型与 hasMany 和 belongsTo 相互关系。发票可以包含多个发票项目,一个发票项目仅属于其发票。基本的。
情况: 创作效果很好。但是,当我尝试使用标准 createOrUpdate 更新现有发票时,会发生以下情况。
这就是我使用createOrUpdate的方式:
$invoice->update($invoiceRequest->except('items'));
foreach($items as $item) {
$invoice->invoiceitem()->updateOrCreate(['id'=> $item['id']],$item);
}
我到底错过了什么?
以下是我的$项目的样子
{
"id": "1",
"invoiceable_id": "3",
"fiscal_id": "2",
"itemdue": "2018-01-19",
"description": "a",
"amount": "1000"
},
{
"id": "2",
"invoiceable_id": "2",
"fiscal_id": "2",
"itemdue": "2018-01-20",
"description": "b",
"amount": "1000"
},
{
"id": "3",
"invoiceable_id": "3",
"fiscal_id": "2",
"itemdue": "2018-01-19",
"description": "c",
"amount": "1200"
},
{
"invoiceable_id": "1",
"fiscal_id": "1",
"itemdue": "2018-01-24",
"description": "renewals",
"amount": "100"
}
应更新带有ID的项目,并将最后一项(不带id)创建为新行。有人请让我知道我到底在哪里。如果您需要更多信息,请告诉我
答案 0 :(得分:2)
$items
中的最后一个元素没有id
:
{
"invoiceable_id": "1",
"fiscal_id": "1",
"itemdue": "2018-01-24",
"description": "renewals",
"amount": "100"
}
这就是$item['id']
给你错误的原因。
您可能希望使用以下内容检查数据:
if (isset($item['id']))