如何使用 Eloquent 从 Laravel 中的多个 select 保存数组数据

How to save array data from multiple select in Laravel using Eloquent

我想将来自多个 select 的数据保存到数据库中。因此用户可以在多个 select 中选择多个产品。我试过下面的代码,但我得到了这个错误“ErrorException Array to string conversion”。 这是我的 blade.php

<div class="form-group row" style="display:none;" id="inputbarang">
<label class="col-form-label col-lg-3 col-sm-12">Barang</label>
    <div class="col-lg-4 col-md-9 col-sm-12">
        <select class="form-control m-select2" width="500px" id="kt_select2_1" name="id_product[]" multiple="multiple">
                <option value=""></option>
                @foreach($produk as $p)
                <option value="{{ $p->id }}">{{ $p->product }}</option>
                @endforeach
        </select>
    </div>
</div>

这是我的控制器

$id_promo = Promo::select('id')
   ->where('delete', 0)->orderBy('created_at', 'DESC')
   // ->take(1)
   ->pluck('id')->first();

   $id_product = [];
   $id_product[] = $request->id_product;

   // $id_products = $id_product['id_product'];

   foreach ($id_product as $i) {
           DetailPromo::create([
           'id_promo' => $id_promo,
           'id_product' => $i,
           'det_potongan' => $request->potongan,
           'det_jumlah_potongan' => $request->jumlah_potongan
       ]);
       }

任何帮助将不胜感激,非常感谢

试试下面的代码:

$id_promo = Promo::select('id')
    ->where('delete', 0)
    ->orderBy('created_at', 'DESC')
    // ->take(1)
    ->pluck('id')
    ->first()
;

$id_products = $request->id_product;
foreach ($id_products as $id_product) {
    DetailPromo::create([
        'id_promo' => $id_promo,
        'id_product' => $id_product,
        'det_potongan' => $request->potongan,
        'det_jumlah_potongan' => $request->jumlah_potongan
    ]);
}