繁体   English   中英

Laravel 5.4 updateOrCreate不起作用

[英]Laravel 5.4 updateOrCreate doesnt work

我有的:

InvoiceInvoiceitems模型与hasManybelongsTo相互关系。 发票可以包含多个发票项目,一个发票项目仅属于其发票。 基本的。

情况:创建工作正常。 但是,当我尝试使用标准createOrUpdate更新现有发票时,会发生以下情况。

  1. 如果尚未创建新行,则会更新现有发票。
  2. 如果我添加了新的发票项目,它会给出未定义的索引:id错误。

这就是我使用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)创建为新行。 有人请让我知道我到底在哪里。 如果您需要更多信息,请告诉我

$items中的最后一个元素没有id

{
    "invoiceable_id": "1",
    "fiscal_id": "1",
    "itemdue": "2018-01-24",
    "description": "renewals",
    "amount": "100"
}

这就是$item['id']给你错误的原因。

您可能想要使用以下内容检查数据:

if (isset($item['id']))

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM