是否有array_merge的替代方案?

问题描述 投票:2回答:2

问题是,我没有得到我的数组代码的预期结果。

我已经尝试过做array_merge,但它所做的就是合并所有数组。

$medicine_order = $request['medicine_id'];

        array:3 [▼
          0 => "25"
          1 => "32"
          2 => "30"
      ]

      $medicine_quantity = $request['medicine_quantity'];

      array:3 [▼
          0 => "3"
          1 => "10"
          2 => "6"
      ]

      $count = 0;
      foreach ($medicine_order as $id) {
        $item = new Historyitem;
        $item->medicine_id = $id;

        foreach ($medicine_quantity as $id2) {
            $item->historyitem_quantity = $id2;
        }
        $item->save();
        $count++;
    }

我想将这些值存储在我的数据库中。

array:3 [▼
          0 => "25"
          1 => "3"
      ]
 array:3 [▼
          0 => "32"
          1 => "10"
      ] 
array:3 [▼
          0 => "30"
          1 => "6"
      ]

但相反,我得到这些值:

array:3 [▼
          0 => "25"
          1 => "6"
      ]
 array:3 [▼
          0 => "32"
          1 => "6"
      ] 
array:3 [▼
          0 => "30"
          1 => "6"
      ]
php arrays laravel-5.4
2个回答
2
投票

解决方案是将您的foreach循环更改为:

$count = 0;
foreach ($medicine_order as $key=>$id) {
    $item = new Historyitem;
    $item->medicine_id = $id;
    $item->historyitem_quantity = $medicine_quantity[$key];
    $item->save();
    $count++;
}

你得到错误结果的原因是,你的内部foreach循环,它迭代你的$medicine_quantity数组的每个元素,每次用新值替换旧值,因此你得到最后一个索引的值,即“6”in最后结果。


2
投票

您需要以与$medicine_quantity值相同的顺序处理$medicine_order值,您可以通过将键与每个数组匹配来完成。试试这个:

foreach ($medicine_order as $key => $id) {
    $item = new Historyitem;
    $item->medicine_id = $id;
    $item->historyitem_quantity = $medicine_quantity[$key];
    $item->save();
    $count++;
}
© www.soinside.com 2019 - 2024. All rights reserved.